diff options
author | Santosh G. Vattam | 2009-10-09 12:09:08 +0530 |
---|---|---|
committer | Santosh G. Vattam | 2009-10-09 12:09:08 +0530 |
commit | 4470b8e1445b091e9e06ec2c8adbc54c28a349e2 (patch) | |
tree | f3e74ad044c72199dfe00bca7033610e8ccb0bac /day1/Session-3.tex | |
parent | 7e1335294c63d326a951c0fc5ecf4ee308583f8f (diff) | |
download | workshops-4470b8e1445b091e9e06ec2c8adbc54c28a349e2.tar.gz workshops-4470b8e1445b091e9e06ec2c8adbc54c28a349e2.tar.bz2 workshops-4470b8e1445b091e9e06ec2c8adbc54c28a349e2.zip |
Session 3 slides completed.
Diffstat (limited to 'day1/Session-3.tex')
-rwxr-xr-x | day1/Session-3.tex | 87 |
1 files changed, 72 insertions, 15 deletions
diff --git a/day1/Session-3.tex b/day1/Session-3.tex index c43db9c..d518781 100755 --- a/day1/Session-3.tex +++ b/day1/Session-3.tex @@ -112,9 +112,13 @@ \section{\typ{for}, Lists and Tuples} -\begin{frame} - {Problem set 3} - As you can guess, idea is to use \kwrd{for}! +\begin{frame}{Quick Recap} + \begin{itemize} + \item List indexing and slicing + \item The \kwrd{range()} function + \item \kwrd{for} + \item Iterating lists and tuples using \kwrd{for} and \kwrd{range()} + \end{itemize} \end{frame} \begin{frame}{Problem 3.1} @@ -141,7 +145,7 @@ \end{frame} \begin{frame}[fragile] - \frametitle{Problem 3.4a} + \frametitle{Problem 3.4} Use the \typ{linspace} function and generate a list of N tuples of the form\\ \typ{[($x_1$,f($x_1$)),($x_2$,f($x_2$)),\ldots,($x_N$,f($x_N$))]}\\for the following functions,\begin{itemize} @@ -151,7 +155,7 @@ Use the \typ{linspace} function and generate a list of N tuples of the form\\ \end{frame} \begin{frame}[fragile] - \frametitle{Problem 3.4b} + \frametitle{Problem 3.5} Using the tuples generated earlier, determine the intervals where the roots of the functions lie. @@ -162,7 +166,7 @@ Use the \typ{linspace} function and generate a list of N tuples of the form\\ % TIME: 15 m, running 185m %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -\section{Input/Output} +\section{Parsing} \begin{frame}[fragile] \frametitle{Simple tokenizing and parsing} @@ -182,6 +186,8 @@ for word in s.split(): \end{lstlisting} \end{frame} +\section{Input/Output} + \begin{frame}[fragile] \frametitle{File handling} \begin{lstlisting} @@ -205,13 +211,59 @@ Writing files \begin{frame}[fragile] \frametitle{File and \kwrd{for}} \begin{lstlisting} ->>> f = open('/path/to/file_name') +$ cat dummyfile +One 1 +Two 2 +Three 3 +Four 4 +Five 5 +Six 6 +Seven 7 +Eight 8 +Nine 9 +Ten 10 +\end{lstlisting} +\end{frame} + +\begin{frame}[fragile] + \frametitle{File and \kwrd{for}} +\begin{lstlisting} +>>> f = open('dummyfile') >>> for line in f: ... print line ... \end{lstlisting} \end{frame} +\begin{frame}[fragile] + \frametitle{File and \kwrd{for}} +\begin{lstlisting} +In [1]: f = open('dummyfile') + +In [2]: for line in f: + ...: print line + ...: +\end{lstlisting} + +\begin{columns} + \column{0.3\textwidth} + +\begin{lstlisting} +One 1 + +Two 2 + +Three 3 +\end{lstlisting} + \column{0.6\textwidth} +\pause +\begin{block}{What happens when ...} +the \kwrd{print line} is replaced by \kwrd{print line,} +\end{block} +\end{columns} +\ldots +\end{frame} + \begin{frame}{Problem 4.2} The given file has lakhs of records in the form:\\ \typ{RGN;ID;NAME;MARK1;\ldots;MARK5;TOTAL;PFW}\\ @@ -344,10 +396,10 @@ def lcm(a, b): % TIME: 25 m, running 230m %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% -\section{Coding Style in Python} +\section{Coding Style} \begin{frame}{Readability and Consistency} \begin{itemize} - \item Readability Counts!-Code is read more often than its written. + \item Readability Counts!\\Code is read more often than its written. \item Consistency! \item Know when to be inconsistent. \end{itemize} @@ -386,6 +438,7 @@ def lcm(a, b): \item Ending the docstrings \item One liner docstrings \end{itemize} +More information at PEP8: http://www.python.org/dev/peps/pep-0008/ \inctime{10} \end{frame} @@ -394,7 +447,7 @@ def lcm(a, b): %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \section{Objects} -\begin{frame}{Objects in Python} +\begin{frame}{Objects in general} \begin{itemize} \item What is an Object? (Types and classes) \item identity @@ -403,10 +456,12 @@ def lcm(a, b): \end{itemize} \end{frame} -\begin{frame}{Everything is an Object!} +\begin{frame}{Almost everything is an Object!} \begin{itemize} - \item \typ{list, tuple} - \item \typ{string, dictionary} + \item \typ{list} + \item \typ{tuple} + \item \typ{string} + \item \typ{dictionary} \item \typ{function} \item Of course, user defined class objects! \end{itemize} @@ -429,7 +484,7 @@ In [3]: l.<tab> \end{frame} \begin{frame}[fragile] - \frametitle{Objects provide a certain consistency} + \frametitle{Objects provide consistency} \small \begin{lstlisting} for element in (1, 2, 3): @@ -455,7 +510,9 @@ for line in urllib2.urlopen('http://site.com'): \begin{frame}{What have we learnt so far?} \begin{itemize} - \item Writing to and Reading from files using \typ{for} + \item Operating on lists and tuples using \kwrd{for} + \item Simple string tokenizing and parsing + \item Writing to and Reading from files using \kwrd{for} \item Using and writing Python Modules \item Coding Style \item Objects in Python |