Home >Backend Development >Python Tutorial >Python 2.7 basic tutorial: overview
.. _tut-informal:
************************************************ *********
An Informal Introduction to Python Python overview
********************************** *********************
In the following examples, input and output are distinguished by the presence or
absence of prompts (``>>> ;`` and ``...``): to repeat the example, you must type
everything after the prompt, when the prompt appears; lines that do not begin
with a prompt are output from the interpreter. Note that a secondary prompt on a
line by itself in an example means you must type a blank line; this is used to
end a multi-line command.
In the following example, the input and output are represented by the greater than sign and the Period prompt ( ``>>>`` and
```...``` ) annotation. If you want to reproduce these examples, enter the lines of code that do not contain the prompt (after the prompt
) after the interpreter prompt. It should be noted that the slave prompt encountered in the exercise means that you need to enter an extra blank line at the end so that the interpreter can know that this is the end of a multi-line command.
Many of the examples in this manual, even those entered at the interactive
prompt, include comments. Comments in Python start with the hash character,
``#``, and extend to the end of the physical line. A comment may appear at the
start of a line or following whitespace or code, but not within a string
literal. A hash character within a string literal is just a hash character.
Since comments are to clarify code and are not interpreted by Python, they may
be omitted when typing in examples.
Many examples in this manual—including those with an interactive prompt—contain comments.
Comments in Python start with the # character and continue until the end of the actual line (Translation - the original author used
``physical line`` to represent actual line breaks instead of the editor's automatic line breaks). Comments can start at the beginning of the line, or after whitespace or code, but do not appear in the string. The #
characters in text strings simply represent # . Comments in the code will not be interpreted by Python, you can ignore them when entering examples.
Some examples::
# this is the first comment
SPAM = 1 = "# This is not a comment."
.. _tut-calculator:
Using Python as a Calculator
============================== ===================
Let's try some simple Python commands. Start the interpreter and wait for the
primary prompt, ``>>>`` . (It shouldn't take long.)
Let's try some simple Python commands. Start the interpreter and wait for the main prompt ``>>>``
to appear (it doesn't take long).
.. _tut-numbers:
Numbers Numerical values
------------
The interpreter acts as a simple calculator: you can type an expression at it
and it will write the value. Expression syntax is straightforward: the
operators ``+``, ``-``, ``*`` and ``/`` work just like in most other languages
(for example, Pascal or C ); parentheses can be used for grouping. For example::
The interpreter is represented like a simple calculator: you can enter some expressions into it and it will return the
value. The expression syntax is straightforward: the operators ``+``, ``-``, ``*`` and ``/`` are the same as in other languages (e.g. Pascal or C); parentheses are used Group. For example::
>>> 2+2
4
>>> # This is a comment
... 2+2
4
>>> 2 +2 # and a comment on the same line as code
4
>>> (50-5*6)/4
5
>>> # Integer division returns the floor:
... 7/3
2
>>> 7/-3
-3
The equal sign (``'='``) is used to assign a value to a variable . Afterwards, no
result is displayed before the next interactive prompt::
The equal sign ( ``'='`` ) is used to assign values to variables::
>>> width = 20
> ;>> height = 5*9
>>> width * height
900
A value can be assigned to several variables simultaneously::
A value can be assigned to several variables simultaneously::
>>> x = y = z = 0 # Zero x, y and z
>>> ed a value) before they can be used, or an
error will occur::
Variables must be "defined" (assigned) before use, otherwise an error will occur::
>>> # try to access an undefined variable
. .. n
Traceback (most recent call last):
File "
NameError: name 'n' is not defined
There is full support for floating point; operators with mixed type operands
convert the integer operand to floating point::
Floating point numbers have complete support; when mixed with integer calculations, they will automatically be converted to floating point numbers::
>>> 3 * 3.75 / 1.5
7.5
>>> 7.0 / 2
3.5
Complex numbers are also supported; imaginary numbers are written with a suffix
of ``j`` or ``J`` . Complex numbers with a nonzero real component are written as
``(real+imagj)``, or can be created with the ``complex(real, imag)`` function.
::
Complex numbers are also obtained Supported; numbers with the suffix ``j`` or ``J`` are treated as imaginary numbers. A complex
number with a non-zero real part is written as ``(real+imagj)``, or can be created using the ``complex(real, imag)`` function::
>>> 1j * 1J
(-1+0j)
>>> 1j * complex(0,1)
(-1+0j)
>>> 3+1j*3
(3 +3j)
>>> (3+1j)*3
(9+3j)
>>> (1+2j)/(1+1j)
(1.5+0.5 j)
Complex numbers are always represented as two floating point numbers, the real
and imaginary part. To extract these parts from a complex number *z*, use
``z.real`` and ``z. imag``. ::
The real and imaginary parts of a complex number are always recorded as two floating point numbers. To extract the real and imaginary parts from a complex number *z*, use ``z.real`` and ``z.imag`` . ::
>>> a=1.5+0.5j
>>> a.real
1.5
>>> a.imag
0.5
functions to floating point and integer (:func:`float`,
:func:`int` and :func:`long`) don't work for complex numbers --- there is no one
correct way to convert a complex number to a real number. Use ``abs(z)`` to get
its magnitude (as a float) or ``z.real`` to get its real part. ::
between floating point numbers and integers The conversion functions ( :func:`float` and :func:`int` and
:func:`long` ) cannot be used with complex numbers. There is no correct way to convert a complex number into a real
number. The function ``abs(z)`` is used to get its modulus (floating point number) or ``z.real`` to get its real part::
>>> a=3.0+4.0j
>> ;> float(a)
Traceback (most recent call last):
File "
TypeError: can't convert complex to float; use abs(z)
>>> a.real
3.0
>>> a.imag
4.0
>>> abs(a) # sqrt(a.real**2 + a .imag**2)
5.0
In interactive mode, the last printed expression is assigned to the variable
``_``. This means that when you are using Python as a desk calculator, it is
somewhat easier to continue calculations, for example::
In interactive mode, the value of the latest expression is assigned to the variable ``_``. In this way, we can use it as a desktop calculator, which is very convenient for continuous calculations, such as::
>>> tax = 12.5 / 100
>>> price = 100.50
>>> price * tax
12.5625
>>> price + _
113.0625
>>> round(_, 2)
113.06
This variable should be treated as read-only by the user. Don't explicitly
assign a value to it --- you would create an independent local variable with the
same name masking the built-in variable with its magic behavior.
This variable is read-only to the user. Don't try to assign a value to it - you will just create a separate local variable with the same name, which blocks the magic effect of the system's built-in variables.
.. _tut-strings:
Strings Strings
--------------
Besides numbers, Python can also manipulate strings, which can be expressed in
several ways. They can be enclosed in single quotes or double quotes::
Compared to numbers, Python also provides strings that can be passed in several different ways. They can be identified with
single or double quotes::
>>> 'spam eggs'
'spam eggs'
>>> 'doesn/'t'
"doesn' t"
>>> "doesn't"
"doesn't"
>>> '"Yes," he said.
>>> "/"Yes,/" he said."
'"Yes," he said.'
>>> '"Isn/'t," she said.'
'"Isn/'t," she said.'
String literals can span multiple lines in several ways. Continuation lines can
be used, with a backslash as the last character on the line indicating that the
next line is a logical continuation of the line::
There are several ways to break string literals into lines. You can use a backslash as a continuous string at the end of a line, which indicates that the next line is logically the continuation of this line.
hello = "This is a rather long string containing/n/
several lines of text just as you would do in C./n/
Note that whitespace at the beginning of the line is/
significant."
print hello
Note that newlines still need to be embedded in the string using ``/n`` -- the
newline following the trailing backslash is discarded. This example would print
the following:
need to note Yes, you still need to write ``/n`` in the string - the trailing backslash will be ignored. The previous
regular meeting is printed as follows:
.. code-block:: text
This is a rather long string containing
several lines of text just as you would do in C.
Note that whitespace at the beginning of the line is significant.
Or, strings can be surrounded in a pair of matching triple-quotes: ``"""`` or
``'''``. End of lines do not need to be escaped when using triple-quotes, but
they will be included in the string. . In triple quotes,
does not need to be escaped, they are already included in the string::
print """
Usage: thingy [OPTIONS]
-H hostname Hostname to connect to
"""
produces the following output:
.. code-block:: text
Usage: thingy [OPTIONS]
play this usage message
-H hostname Hostname to connect to
If we make the string literal a "raw" string, ``/n`` sequences are not converted
to newlines, but the backslash at the end of the line, and the newline character
in the source, are both included in the string as data. Thus, the example::
If we generate a "raw" string, the ``/n`` sequences will not be escaped, and the end-of-line Backslashes
and line breaks in the source code become part of the data in the string, so the following example::
hello = r"This is a rather long string containing/n/
several lines of text much as you would do in C."
print hello
would print:
would print:
.. code-block:: text
This is a rather long string containing/n/
several lines of text much as you would do in C.
The interpreter prints the result of string operations in the same way as they
are typed for input: inside quotes, and with quotes and other funny characters
escaped by backslashes, to show the precise value. The string is enclosed in
double quotes if the string contains a single quote and no double quotes, else
it's enclosed in single quotes. (The :keyword:`print` statement, described
later, can be used to write strings without quotes or escapes.)
The interpreter prints the results of string operations the same way they were entered: as parentheses, containing interesting characters escaped by backslashes, to display the value accurately. If a string contains single quotes but not double quotes, it is marked with double quotes. Otherwise it is identified by single quotes. (The
:keyword:`print` statement introduced later can output strings without identification and escape.)
Strings can be concatenated (glued together) with the ``+`` operator, and
repeated with ``*``::
Strings can be connected (glued together) by the ``+`` operator, and can be repeated by ``*``::
>>> word = 'Help' + 'A'
>>> word
'HelpA'
>>> '<' + word*5 + '>'
'
T wo string literals next to each other are automatically concatenated; the first
line above could also have been written ``word = 'Help' 'A'``; this only works
with two literals, not with arbitrary string expressions::
Two adjacent string texts are automatically connected together. The previous line of code can also be written as
``word ='Help' 'A'``. It is only used for two string texts and cannot be used. for string expressions.
>>> 'str' 'ing' # <- This is ok
'string'
>>> 'str'.strip() + 'ing' # <- This is ok
'string'
>>> 'str'.strip() 'ing' # <- This is invalid
File "
' Str'.Strip () 'Ing'
^
Syntaxerror: Invalid Syntax
strings Can Be Subscripted (Indexed); Like in C, The First Character of a String
has Subscript (IND EX) 0. There is no separate character type; a character is
simply a string of size one. Like in Icon, substrings can be specified with the
*slice notation*: two indices separated by a colon. ::
Strings can also be intercepted (retrieval). Similar to C , the first character of a string is indexed 0 . There is no independent character type. A character is a string of length 1. Similar to Icon , you can use the
*slicing annotation* method to intercept strings: copies split by two indices. ::
>>> word[4]
'A'
>>> word[0:2]
'He'
>>> word[2: 4]
'lp'
Slice indices have useful defaults; an omitted first index defaults to zero, an
omitted second index defaults to the size of the string being sliced. ::
Index slices can have default values, When slicing, if the first index is ignored, it defaults to 0, and if the second
index is ignored, it defaults to the length of the string. (In fact, there is a third parameter, which represents the slicing step size. It defaults to
1, and the complete slicing operation is word[2:4:1] - Translator) ::
>>> word [:2] # The first two characters
'He'
>>> word[2:] # Everything except the first two characters
'lpA'
Unlike a C string, Python strings cannot be changed. Assigning to an indexed
position in the string results in an error::
Unlike C strings, Python strings are immutable. Assigning a value to an index of a string literal will cause an error::
>>> word[0] = 'x'
Traceback (most recent call last):
File " TypeError: object does not support item assignment >>> word[:1] = 'Splat' Traceback (most recent call last): File "< ;stdin>", line 1, in ? TypeError: object does not support slice assignment However, creating a new string with the combined content is easy and efficient:: However, combining text content to generate a new text is simple And efficient:: >>> 'x' + word[1:] 'xelpA' >>> 'Splat' + word[4] 'SplatA' Here's a useful invariant of slice operations: ``s[:i] + s[i:]`` equals ``s``. :: Slice operations have a useful invariant : ``s[:i] + s[i:]`` is equal to ``s``. :: >>> word[:2] + word[2:] 'HelpA' >>> word[:3] + word[3:] 'HelpA' Degenerate slice indices are handled gracefully: an index that is too large is replaced by the string size, an upper bound smaller than the lower bound returns an empty string. :: Degenerate slice retrieval is graceful: If the upper limit is too large, it will be replaced by the text length. If the upper limit is smaller than the lower limit, an empty string will be returned. :: >>> word[1:100] 'elpA' >>> word[10:] '' >>> word[2: 1] '' Indices may be negative numbers, to start counting from the right. For example:: Indices may be negative numbers, to start counting from the right end. For example:: >>> word[-1] # The last character 'A' >>> word[-2] # The last-but-one character 'p ' >>> word[-2:] # The last two characters 'pA' >>> word[:-2] # Everything except the last two characters 'Hel ' But note that -0 is really the same as 0, so it does not count from the right! :: But note that -0 is really the same as 0, so it does not count from the right! ! >>> word[-0] # (since -0 equals 0) 'H' Out-of-range negative slice indices are truncated, but don't try this for single- element (non-slice) indices:: Negative index slices will be truncated if they cross the boundary. Do not try to use it for single element (non-slice) retrieval:: >>> word[-100:] 'HelpA' >>> word[-10] # error Traceback (most recent call last): File " IndexError: string index out of range One way to remember how slices work is to think of the indices as pointing *between* characters, with the left edge of the first character numbered 0. Then the right edge of the last character of a string of *n* characters has index *n*, for example:: There is a way to easily remember how slicing works: the index when slicing is between two characters **. The index of the first character on the left is 0, and the last character of a string of length *n* has an index of the right bound of *n*. For example:: +---+---+---+---+---+ | H | e | l | p | A | +---+---+ ---+---+---+ 0 1 2 3 4 5 -5 -4 -3 -2 -1 The first row of numbers gives the position of the indices 0...5 in the string; the second row gives the corresponding negative indices. The slice from *i* to *j* consists of all characters between the edges labeled *i* and *j*, respectively. text The first line of numbers in gives the index points 0...5 in the string. The second line gives the corresponding negative index. The slice is all the characters between the boundaries marked by the two values from *i* to *j*. For non-negative indices, the length of a slice is the difference of the indices, if both are within bounds. For example, the length of ``word[1:3]`` is 2. For non-negative indexes, if both top and bottom are within the bounds, the slice length is different from the index. For example, ``word[1:3]`` is 2 . The built-in function :func:`len` returns the length of a string:: The built-in function:func:`len` returns the length of a string:: >>> s = 'supercalifragilisticexpialidocious' >>> len(s) 34 .. seealso:: :ref:`typesseq` Strings, and the Unicode strings described in the next section, are examples of * sequence types*, and support the common operations supported by such types. :ref:`string-methods` Both strings and Unicode strings support a large number of methods for basic transformations and searching. :ref:`new-string-formatting` Information about string formatting with :meth:`str.format` is described here. :ref:`string-formatting` The old formatting operations invoked when strings and Unicode strings are the left operand of the ``%`` operator are described in more detail here. .. _tut-unicodestrings: Unicode Strings Unicode text --------- ------------------- .. sectionauthor:: Marc-Andre Lemburg Starting with Python 2.0 a new data type for storing text data is available to the programmer: the Unicode object. It can be used to store and manipulate Unicode data (see http://www.unicode.org/) and integrates well with the existing string objects, providing auto-conversions where necessary. Starting with Python 2.0, programmers have a new type for storing text data: Unicode objects. It can be used to store and maintain Unicode data (see http://www.unicode.org/), and has good integration with existing string objects, providing automatic conversion when necessary. Unicode has the advantage of providing one ordinal for every character in every script used in modern and ancient texts. Previously, there were only 256 possible ordinals for script characters. Texts were typically bound to a code page which mapped the ordinals to script characters. This lead to very much confusion especially with respect to internationalization (usually written as ``i18n`` --- ``'i'`` + 18 characters + ``'n' ``) of software. Unicode solves these problems by defining one code page for all scripts. The advantage of Unicode is that it provides for every character that appears in every writing system in use, modern or ancient. a unified serial number. Previously, there were only 256 possible orders for characters in a writing system. Mapping by code page demarcation. The text is bound to the code page of the mapping text system. This is especially troublesome when software is internationalized (usually written as ``i18n`` - ``'i'`` + 18 characters + ``'n'``). Unicode solves the problem of setting up a separate code page for all writing systems. Creating Unicode strings in Python is just as simple as creating normal strings:: Creating Unicode strings in Python is just as simple as creating normal strings:: >>> u'Hello World !' u'Hello World !' The small ``'u'`` in front of the quote indicates that a Unicode string is supposed to be created. If you want to include special characters in the string, you can do so by using the Python *Unicode-Escape* encoding. The following example shows how:: The ``'u'`` before the quotes means this will create a Unicode string. If you want to include special characters in a string, you can use Python's *Unicode-Escape* (Unicode escape - translator). Please see the example below:: >>> u'Hello/u0020World !' u'Hello World !' For experts, there is also a raw mode just like the one for normal strings . You have to prefix the opening quote with 'ur' to have unevenPython use the *Raw-Unicode-Escape* encoding. It will only apply the above ``/uXXXX`` conversion if there is an uneven number of backslashes in front of the small 'u'. :: Specially, like ordinary strings, Unicode strings also have primitive modes. You can add "ur" before the quotation marks, and Python will use *Raw-Unicode-Escape* encoding (raw Unicode escape - translator ). If there is a value prefixed with '/u', it will only be displayed as ``/uXXXX``. :: >>> ur'Hello/u0020World !' u'Hello World !' >>> ur'Hello//u0020World !' u'Hello//// u0020World !' The raw mode is most useful when you have to enter lots of backslashes, as can be necessary in regular expressions. If you need to enter lots of backslashes, the raw mode is most useful, which is in regular expressions It is almost necessary to have in the formula. Apart from these standard encodings, Python provides a whole set of other ways of creating Unicode strings on the basis of a known encoding. A complete set of methods for strings of characters . .. index:: builtin: unicode The built-in function :func:`unicode` provides access to all registered Unicode codecs (COders and DECoders). Some of the more well known encodings which these codecs can convert are *Latin-1*, *ASCII*, *UTF-8*, and *UTF-16*. The latter two are variable-length encodings that store each Unicode character in one or more bytes . The default encoding is normally set to ASCII, which passes through characters in the range 0 to 127 and rejects any other characters with an error. When a Unicode string is printed, written to a file, or converted with :func:`str`, conversion takes place using this default encoding. :: The built-in function :func:`unicode` can use all registered Unicode encodings (COders and DECoders). As we all know, encodings of *Latin-1*, *ASCII*, *UTF-8* and *UTF-16* can be converted to each other (Latin-1 represents a small set of Latin language symbols, which is the same as ASCII base This is consistent, but it cannot be used to represent a huge set of Eastern language characters - Translator). The latter two are variable-length encodings that store each Unicode character as one or more bytes. The default encoding is usually ASCII. This encoding accepts encodings in the range of 0 to 127, otherwise an error will be reported. When printing or writing a Unicode string to a file, or using :func:`str` to convert, the conversion operation uses this as the default encoding. :: >>> u"abc" u'abc' >>> str(u"abc") 'abc' >>> u" ü" u'/xe4/xf6/xfc' >>> str(u"ü") Traceback (most recent call last): File " UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-2: ordinal not in range(128) To convert a Unicode string into an 8-bit string using a specific encoding, Unicode objects provide an :func:`encode` method that takes one argument, the name of the encoding. Lowercase names for encodings are preferred. :: In order to write a Unicode string as an 8-bit character using a specific encoding String, Unicode object provides a :func:`encode` method, which accepts the encoding name as a parameter. Encoding names should be lowercase. :: >>> u"ü".encode('utf-8') '/xc3/xa4/xc3/xb6/xc3/xbc' If you have data in a specific encoding and want to produce a corresponding Unicode string from it, you can use the :func:`unicode` function with the encoding name as the second argument. For a Unicode string, you can use the :func:`unicode` function, which accepts the encoding name as the second parameter. :: >>> unicode('/xc3/xa4/xc3/xb6/xc3/xbc', 'utf-8') u'/xe4/xf6/xfc' .. _tut- lists: Lists List ---------- Python knows a number of *compound* data types, used to group together other values. The most versatile is the *list*, which can be written as a list of comma-separated values (items) between square brackets. List items need not all have the same type. :: Python has several *composite* data types for splitting other values. The most general is *list* (list of columns), which can be written as a list of comma-separated values between brackets. The elements of the list do not have to be of the same type. :: >>> a = ['spam', 'eggs', 100, 1234] >>> a ['spam', 'eggs', 100, 1234] Like string indices, list indices start at 0, and lists can be sliced, concatenated and so on:: Like string indices, lists can be retrieved starting from 0. Lists can be sliced and concatenated:: >>> a[0] 'spam' >>> a[3] 1234 >>> a[ -2] 100 >>> a[1:-1] ['eggs', 100] >>> a[:2] + ['bacon', 2 *2] ['spam', 'eggs', 'bacon', 4] >>> 3*a[:3] + ['Boo!'] ['spam', ' eggs', 100, 'spam', 'eggs', 100, 'spam', 'eggs', 100, 'Boo!'] All slice operations return a new list containing the requested elements. This means that the The following slice returns a shallow copy of the list *a*:: All slicing operations will return a new list containing the calculated elements. This means that the following slicing operation returns a shallow copy of the list *a* :: >>> a[:] ['spam', 'eggs', 100, 1234] Unlike strings, which are *immutable*, it is possible to change individual elements of a list: : Unlike *immutable* strings, lists allow elements to be modified:: >>> a ['spam', 'eggs', 100, 1234] >>> ; a[2] = a[2] + 23 >>> a ['spam', 'eggs', 123, 1234] Assignment to slices is also possible, and this can even change the size of the list or clear it entirely:: can also be assigned to slices. This operation can change the size of the list or clear it:: >>> # Replace some items: . .. a[0:2] = [1, 12] >>> a [1, 12, 123, 1234] >>> # Remove some: .. . a[0:2] = [] >>> a [123, 1234] >>> # Insert some: ... a[1:1] = ['bletch', 'xyzzy'] >>> a [123, 'bletch', 'xyzzy', 1234] >>> # Insert (a copy of) itself at the beginning >>> a[:0] = a >>> a [123, 'bletch', 'xyzzy', 1234, 123, 'bletch', 'xyzzy' [ ] The built-in function :func:`len` also applies to lists:: The built-in function :func:`len` also applies to lists:: >>> a = ['a ', 'b', 'c', 'd'] >>> len(a) 4 It is possible to nest lists (create lists containing other lists), for example: : allows nested lists (creating a list containing other lists), for example:: >>> q = [2, 3] >>> p = [1, q, 4] >>> len(p) 3 >>> p[1] [2, 3] >>> p[1][0 ] 2 >>> p[1].append('xtra') # See section 5.1 >>> p [1, [2, 3, 'xtra'] , 4] >>> q [2, 3, 'xtra'] Note that in the last example, ``p[1]`` and ``q`` really refer to the same object! We'll come back to *object semantics* later. Note that in the last example, ``p[1]`` and ``q`` actually point to the same object! We will continue the discussion in *object semantics* later in . .. _tut-firststeps: First Steps Towards Programming ================================ ============== Of course, we can use Python for more complicated tasks than adding two and two together. For instance, we can write an initial sub-sequence of the * Fibonacci* series as follows:: Of course, we can use Python to complete more complex tasks than two plus two. For example, we can write a program that generates *Fibonacci* subsequences as follows:: >>> # Fibonacci series: ... # the sum of two elements defines the next ... a, b = 0, 1 >>> while b < 10: ... print b ... a, b = b, a+b ... 1 1 2 3 5 8 This example introduces several new features. This example introduces several new features. * The first line contains a *multiple assignment*: the variables ``a`` and ``b`` simultaneously get the new values 0 and 1. On the last line this is used again, demonstrating that the expressions on the right-hand side are all evaluated first before any of the assignments take place. The right-hand side expressions are evaluated from the left to the right. The first line contains a *multiple assignment *: Variables ``a`` and ``b`` obtained new values 0 and 1 . The last line is used again. In this demonstration, before variable assignment, the calculation of is completed first on the right side. The expression on the right is evaluated from left to right. * The :keyword:`while` loop executes as long as the condition (here: ``b < 10``) remains true. In Python, like in C, any non-zero integer value is true; zero is false. The condition may also be a string or list value, in fact any sequence; anything with a non-zero length is true, empty sequences are false. The test used in the example is a simple comparison. The standard comparison operators are written the same as in C: ``<`` (less than), ``>`` (greater than), ``==`` (equal to) , ``<=`` (less than or equal to), ``>=`` (greater than or equal to) and ``!=`` (not equal to). Condition (here When ``b Python, similar to C, any non-zero integer is true; 0 is false. The condition can also be a string or a list, in fact it can be any sequence; all non-zero lengths are true, and empty columns are false. The test in the example is a simple comparison. The standard comparison operators are the same as in C: ``<`` (less than), ``>`` (greater than), ``==`` (equal to), ``<=`` (less than etc. ≥), ``>=`` (greater than or equal to) and ``!=`` (not equal to). * The *body* of the loop is *indented*: indentation is Python's way of grouping statements. Python does not (yet!) provide an intelligent input line editing facility, so you have to type a tab or space(s) for each indented line. In practice you will prepare more complicated input for Python with a text editor; most text editors have an auto-indent facility. When a compound statement is entered interactively, it must be followed by a blank line to indicate completion (since the parser cannot guess when you have typed the last line). Note that each line within a basic block must be indented by the same amount. Loop*body* It's *indented*: Indentation is Python's way of organizing statements. Python doesn’t (yet) offer integrated line editing, so you’ll have to enter TAB or a space for each indented line. In practice, it is recommended that you find a text editor to enter complex Python programs. Most text editors provide automatic indentation. When entering compound statements interactively, you must enter a blank line at the end to mark the end (because the interpreter cannot guess which line you input is the last line). What needs to be noted is that statements in the same statement block Blocks must be indented by the same amount of white space. * The :keyword:`print` statement writes the value of the expression(s) it is given. It differs from just writing the expression you want to write (as we did earlier in the calculator examples) in the way it handles multiple expressions and strings. Strings are printed without quotes, and a space is inserted between items, so you can format things nicely, like this:: Keyword:keyword:`print` Statement output The value of the given expression. It controls the output of multiple expressions and strings into the string you want (just like we did in the previous calculator example). Strings are printed without quotation marks, and spaces are inserted between each two sub-items, so you can make the format very beautiful, like this:: >>> i = 256*256 >>> print 'The value of i is', i The value of i is 65536 A trailing comma avoids the newline after the output:: You can disable output newline by ending it with a comma :: a+b completed ... 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 Note that the interpreter inserts a newline before it prints the next prompt if the last line was not . Note that here, if the last line is not completely output, the interpreter will insert a newline before it prints the next prompt. The above is the summary of the basic tutorial of Python 2.7. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!