Differences between revisions 2 and 3
Revision 2 as of 2008-04-10 15:18:17
Size: 8089
Editor: anonymous
Comment:
Revision 3 as of 2008-04-11 15:17:40
Size: 7389
Editor: anonymous
Comment:
Deletions are marked like this. Additions are marked like this.
Line 107: Line 107:
\begin{frame}[fragile]\frametitle{Variables, assignment}
The \textbf{assignment statement =} creates new variables and gives them values
\begin{verbatim}
== Variables, assignment ==
The assignment statement = creates new variables and gives them values
{{{
Line 114: Line 114:
\end{verbatim}
\vfill
\end{frame
}

\begin{frame}[fragile]\frametitle{Lists and tuples}
\begin{itemize}
\item
Lists \textbf{[]} are mutable sequences of values
\item Tuples \textbf{()} can not be changed (immutable)
\end{itemize}
\tiny
\begin
{verbatim}
}}}

== Lists and tuples ==
 * Lists {{{[]}}} are mutable sequences of values
 * Tuples {{{()}}} can not be changed (immutable)

{{{
Line 142: Line 138:
\end{verbatim}
\vfill
\end{frame
}

\begin{frame}[fragile]\frametitle{Indexing and slicing}
\begin{itemize}
\item
Indices \textbf{[]} select elements of variables
\item Indices start from zero
\item \textbf{[a:b]} selects a slice of elements
\end{itemize}
\tiny
\begin
{verbatim}
}}}

== Indexing and slicing ==
 * Indices  {{{[]}}} select elements of variables
 * Indices start from zero
 * {{{x[a:b]}}} selects a slice of elements from variable x

{{{
Line 178: Line 170:
\end{verbatim}
\vfill
\end{frame}

\begin{frame}[fragile]\frametitle{List built-in functions (methods)}
\begin{itemize}
\item \textbf{L.append(object)} -- append object to end
\item \textbf{L.count(value)} -> integer -- return number of occurrences of value
\item \textbf{L.extend(iterable)} -- extend list by appending elements from the iterable
\item \textbf{L.index(value, [start, [stop]])} -> integer -- return first index of value
\item \textbf{L.insert(index, object)} -- insert object before index
\item \textbf{L.pop([index])} -> item -- remove and return item at index (default last)
\item \textbf{L.reverse()} -- reverse *IN PLACE*
\item \textbf{L.sort()} -- stable sort *IN PLACE*
\end{itemize}
\vfill
\end{frame}


\begin{frame}[fragile]\frametitle{List built-in functions (methods)}
\scriptsize
\begin{verbatim}
}}}

=== List built-in functions (methods) ===

 * {{{L.append(object)}}} -- append object to end
 * {{{L.count(value)}}} -> integer -- return number of occurrences of value
 * {{{L.extend(iterable)}}} -- extend list by appending elements from the iterable
 * {{{L.index(value, [start, [stop]])}}} -> integer -- return first index of value
 * {{{L.insert(index, object)}}} -- insert object before index
 * {{{L.pop([index])}}} -> item -- remove and return item at index (default last)
 * {{{L.reverse()}}} -- reverse *IN PLACE*
 * {{{L.sort()}}} -- sort *IN PLACE*

{{{
Line 216: Line 200:
\end{verbatim}
\vfill
\end{frame}

\begin{frame}[fragile]\frametitle{Nested data structures}
\scriptsize
\begin{verbatim}
}}}

Nested data structures

{{{
Line 244: Line 226:
\end{verbatim}
\vfill
\end{frame}

\begin{frame}[fragile]\frametitle{Dictionary}
}}}

== Dictionary ==

SiaProgrammingPython

Basic Python

Built-in keywords

Python built-in keywords

help> keywords

and                 else                import              raise
assert              except              in                  return
break               exec                is                  try
class               finally             lambda              while
continue            for                 not                 yield
def                 from                or
del                 global              pass
elif                if                  print

Built-in types

Python built-in numeric types

There are four distinct numeric types:

  • plain integers int

  • long integers long

  • floating point numbers float

  • complex numbers complex

In addition, Booleans are a subtype of plain integers

Boolean

Boolean (logical) types

  • True
  • False

Operations

x + y           sum of x and y
x - y           difference of x and y   
x * y           product of x and y      
x / y           quotient of x and y
x // y          (floored) quotient of x and y
x % y           remainder of x / y
-x              x negated       
+x              x unchanged     
abs(x)          absolute value or magnitude of x        
int(x)          x converted to integer
long(x)         x converted to long integer 
float(x)        x converted to floating point   
complex(re,im)  a complex number with real part re, 
                imaginary part im. im defaults to zero
c.conjugate()   conjugate of the complex number c
x ** y          x to the power y

Boolean Operations: and, or, not

x or y          if x is false, then y, else x 
x and y         if x is false, then x, else y 
not x           if x is false, then True, else False    

Comparisons

<               strictly less than      
<=              less than or equal      
>               strictly greater than   
>=              greater than or equal   
==              equal   
!=              not equal       

is              object identity         

Sequence types

  • String str

  • List list

  • Tuple tuple

Operations

x in s  True if an item of s is equal to x, else False  
x not in s      False if an item of s is equal to x, 
        else True       
s + t   the concatenation of s and t    
s[i]    i'th item of s
s[i:j]  slice of s from i to j  
s[i:j:k] slice of s from i to j with step k
len(s)  length of s     
min(s)  smallest item of s      
max(s)  largest item of s       

Variables, assignment

The assignment statement = creates new variables and gives them values

a=2
l=9**1000L
S='Hello'
f=1e5

Lists and tuples

  • Lists [] are mutable sequences of values

  • Tuples () can not be changed (immutable)

In [5]: a=[1,2,3]
In [6]: b=(1,2,3)

In [7]: a[0]
Out[7]: 1

In [8]: b[0]
Out[8]: 1

In [9]: a[0]=4

In [10]: a
Out[10]: [4, 2, 3]

In [11]: b[0]=4
---------------------------------------------------------------------------
exceptions.TypeError 

Indexing and slicing

  • Indices [] select elements of variables

  • Indices start from zero
  • x[a:b] selects a slice of elements from variable x

In [1]: a=range(10)

In [2]: a
Out[2]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

In [3]: a[0:4]
Out[3]: [0, 1, 2, 3]

In [4]: a[4:]
Out[4]: [4, 5, 6, 7, 8, 9]

In [5]: a[:4]
Out[5]: [0, 1, 2, 3]

In [6]: a[:-1]
Out[6]: [0, 1, 2, 3, 4, 5, 6, 7, 8]

In [7]: s='Hello world'
In [8]: s[:5]
Out[8]: 'Hello'

In [9]: a=tuple(range(10))
In [10]: a[0:4]
Out[10]: (0, 1, 2, 3)

List built-in functions (methods)

  • L.append(object) -- append object to end

  • L.count(value) -> integer -- return number of occurrences of value

  • L.extend(iterable) -- extend list by appending elements from the iterable

  • L.index(value, [start, [stop]]) -> integer -- return first index of value

  • L.insert(index, object) -- insert object before index

  • L.pop([index]) -> item -- remove and return item at index (default last)

  • L.reverse() -- reverse *IN PLACE*

  • L.sort() -- sort *IN PLACE*

In [72]: L=['C','A','B']
In [73]: L.sort()

In [74]: L
Out[74]: ['A', 'B', 'C']

In [75]: L.pop()
Out[75]: 'C'

In [76]: L
Out[76]: ['A', 'B']

In [77]: L.insert(1,'C')

In [78]: L
Out[78]: ['A', 'C', 'B']

Nested data structures

In [84]: a=range(10)
In [85]: b=range(0,10,2)
In [86]: b
Out[86]: [0, 2, 4, 6, 8]

In [87]: c=[a,b]

In [88]: c
Out[88]: [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [0, 2, 4, 6, 8]]

In [91]: c[0]
Out[91]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

In [92]: c[1]
Out[92]: [0, 2, 4, 6, 8]

In [93]: c[0][0:4]
Out[93]: [0, 1, 2, 3]

In [94]: c[1][0:4]
Out[94]: [0, 2, 4, 6]

Dictionary

\begin{itemize} \item A dictionary is like a list, but more general. \item In a list, the indices have to be integers; in a dictionary they can be (almost) any type. \item \textbf{d=\{\}} creates empty dictionary \item \textbf{d[key]=value} add a key, value pair to dictionary \item \textbf{d.keys()} returns list of keys \end{itemize} \scriptsize \begin{verbatim} In [95]: D={} In [96]: D['a']=range(10) In [97]: D['b']=range(0,10,2)

In [98]: D Out[98]: {'a': [0, 1, 2, 3, 4, 5, 6, 7, 8, 9], 'b': [0, 2, 4, 6, 8]}

In [99]: D['a'] Out[99]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

In [100]: D.keys() Out[100]: ['a', 'b'] \end{verbatim} \vfill \end{frame}

\begin{frame}[fragile]\frametitle{Loops} \begin{itemize} \item Looping over a list is done for the \textbf{for} statement \item \textbf{enumerate()} returns an enumerated object \end{itemize} \scriptsize \begin{verbatim} In [106]: a=['Hund','Katze','Maus'] In [108]: for i in a:

  • ....: print i
  • ....:

Hund Katze Maus

In [111]: for i,j in enumerate(a):

  • ....: print i,j
  • ....:

0 Hund 1 Katze 2 Maus

\end{verbatim} \vfill \end{frame}

\begin{frame}[fragile]\frametitle{Control statements} \begin{itemize} \item Conditions can be checked with \textbf{if-else} statement \item \textbf{if} condition: indented block \item \textbf{else:} \item condition \end{itemize} \scriptsize \begin{verbatim} In [116]: if a==1:

  • ....: print 'a=1'
  • ....: else:
  • ....: print 'a != 1'
  • ....:

a=1 \end{verbatim} \vfill \end{frame}

\begin{frame}[fragile]\frametitle{Functions} Function with one argument \begin{verbatim} In [124]: def quadrat(x):

  • ....: return x**2
  • ....:

In [125]: quadrat(2) Out[125]: 4 \end{verbatim} \vfill \end{frame}

\begin{frame}[fragile]\frametitle{Functions} Function with variable number of arguments \begin{verbatim} In [126]: def printargs(*args):

  • ....: for arg in args:
  • ....: print arg
  • ....:

In [127]: printargs(a) [1, 2, 3]

In [128]: printargs(a,range(4)) [1, 2, 3] [0, 1, 2, 3] \end{verbatim} \vfill \end{frame}

\begin{frame}[fragile]\frametitle{Functions} Function with variable number of keywords \begin{verbatim} In [131]: def printkeys(**kw):

  • ....: for k in kw.keys():
  • ....: print k,kw[k]
  • ....:

In [132]: printkeys(key1=10,key2='Hallo') key2 Hallo key1 10 \end{verbatim} \vfill \end{frame}

\end{document}

LehreWiki: SiaProgrammingPythonBasicPython (last edited 2008-04-14 09:22:50 by anonymous)