⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 3.html

📁 一个python入门书
💻 HTML
字号:
<HTML><!-- Mirrored from www.math.pku.edu.cn/teachers/lidf/docs/Python/3.html by HTTrack Website Copier/3.x [XR&CO'2005], Fri, 08 Jul 2005 11:49:13 GMT --><HEAD><TITLE>第三章 基本使用</TITLE></HEAD><BODY LINK="#0000ff"><H1>第三章 基本使用</H1><P>下面我们用例子来介绍Python的基本用法。在例子中,用户输入和系统输出靠有没有提示(&gt;&gt;&gt;和...)来分别。如果要试这些例子的话,需要键入提示后的所有命令,例子中没有提示的行是系统的输出。注意只有次提示的行意味着需要键入一个空行,这用于结束多行命令。</P><P> </P><H2>3.1 用Python作计算器使用</H2><P>启动解释程序,等待主提示&gt;&gt;&gt;出现。解释程序可以作为计算器使用。键入一个表达式,解释程序就可以输出结果。表达式的写法很直观:+,-,*,/, %, **等算符的作用和其它大多数语言(如Pascal或C)没什么差别,括号可以用来组合。例如:</P><P> </P><PRE>&gt;&gt;&gt; 2+2 4 &gt;&gt;&gt; # 这是一个注释... 2+24&gt;&gt;&gt; 2+2  # 和代码在同一行的注释4&gt;&gt;&gt; (50-5*6)/45&gt;&gt;&gt; # 整数除法得下面的整数... 7/32&gt;&gt;&gt; 7/-3-3&gt;&gt;&gt;</PRE><P>和C中一样,等于号用来给变量赋值,赋值的结果不显示:</P><PRE>&gt;&gt;&gt; width = 20&gt;&gt;&gt; height = 5*9&gt;&gt;&gt; width * height900&gt;&gt;&gt;</PRE><P>可以同时给几个变量赋同一个值:</P><PRE>&gt;&gt;&gt; x = y = z = 0  # 把 x, y 和 z赋零 &gt;&gt;&gt; x0&gt;&gt;&gt; y0&gt;&gt;&gt; z0&gt;&gt;&gt;</PRE><P>Python完全支持浮点数,混合类型的运算会把整数先转换成浮点数:</P><PRE>&gt;&gt;&gt; 4 * 2.5 / 3.33.0303030303&gt;&gt;&gt; 7.0 / 23.5&gt;&gt;&gt;</PRE><P>Python也提供了复数,方法是用j和J作为虚数单位,如1+1j,3.14e-10j,等等。</P><H2>3.2. 字符串</H2> Python除处理数字外还可以处理字符串,字符串用单撇号或双撇号包裹:<PRE>&gt;&gt;&gt; 'spam eggs''spam eggs'&gt;&gt;&gt; 'doesn\'t'"doesn't"&gt;&gt;&gt; "doesn't""doesn't"&gt;&gt;&gt; '"Yes," he said.''"Yes," he said.'&gt;&gt;&gt; "\"Yes,\" he said."'"Yes," he said.'&gt;&gt;&gt; '"Isn\'t," she said.''"Isn\'t," she said.'&gt;&gt;&gt;</PRE><P>字符串输出格式与输入的样子相同,都是用撇号包裹,撇号和其它特殊字符用用反斜杠转义。如果字符串中有单撇号而没有双撇号则用双撇号包裹,否则应该用单撇号包裹。后面要介绍的print语句可以不带撇号或转义输出字符串。</P><P> 字符串可以用+号连接起来,用*号重复:</P><PRE>&gt;&gt;&gt; word = 'Help' + 'A'&gt;&gt;&gt; word'HelpA'&gt;&gt;&gt; '&lt;' + word*5 + '&gt;''&lt;HelpAHelpAHelpAHelpAHelpA&gt;'&gt;&gt;&gt;</PRE><P>字符串可以象在C中那样用下标索引,字符串的第一个字符下标为0。</P><P>Python没有单独的字符数据类型,一个字符就是长度为一的字符串。象在Icon语言中那样,可以用片段(slice)记号来指定子串,片段即用冒号隔开的两个下标。</P><PRE>&gt;&gt;&gt; word[4]'A'&gt;&gt;&gt; word[0:2]'He'&gt;&gt;&gt; word[2:4]'lp'&gt;&gt;&gt;</PRE><P>片段有很好的缺省值:第一下标省略时缺省为零,第二下标省略时缺省为字符串的长度。</P><PRE>&gt;&gt;&gt; word[:2]    # 前两个字符'He'&gt;&gt;&gt; word[2:]    # 除前两个字符串外的部分'lpA'&gt;&gt;&gt;</PRE><P>注意s[:i] + s[i:] 等于 s 是片段运算的一个有用的恒等式。</P><PRE>&gt;&gt;&gt; word[:2] + word[2:]'HelpA'&gt;&gt;&gt; word[:3] + word[3:] 'HelpA'&gt;&gt;&gt;</PRE><P>不合理的片段下标可以很好地得到解释:过大的下标被换成字符串长度,上界小于下界时返回空串。</P><PRE>&gt;&gt;&gt; word[1:100]'elpA'&gt;&gt;&gt; word[10:]''&gt;&gt;&gt; word[2:1]''&gt;&gt;&gt;</PRE><P>下标允许为负数,这时从右向左数。例如:</P><PRE>&gt;&gt;&gt; word[-1]     # 最后一个字符'A'&gt;&gt;&gt; word[-2]     # 倒数第二个字符'p'&gt;&gt;&gt; word[-2:]    # 最后两个字符'pA'&gt;&gt;&gt; word[:-2]    # 除最后两个字符外的部分'Hel'&gt;&gt;&gt;</PRE><P>但要注意的是 -0 实际还是 0,所以它不会从右向左数!</P><PRE>&gt;&gt;&gt; word[-0]     # (因为 -0 等于 0)'H'&gt;&gt;&gt;</PRE><P>超出范围的片段下标被截断,但在非片段的情况下不要这样:</P><PRE>&gt;&gt;&gt; word[-100:]'HelpA'&gt;&gt;&gt; word[-10]    # 错误Traceback (innermost last):  File "&lt;stdin&gt;", line 1IndexError: string index out of range &gt;&gt;&gt;</PRE><P>记住片段意义的最好方法是把下标看成是字符<B>之间</B>的点,第一个字符的左边界号码为0。有n个字符的字符串的最后一个字符的右边界下标为n,例如:</P><PRE>  +---+---+---+---+---+  | H | e | l | p | A | +---+---+---+---+---+  0   1   2   3   4   5 -5  -4  -3  -2  -1 </PRE><P>第一行数字给出字符串中下标0到5的位置,第二行给出相应的负下标。从i到j的片段由在边界i和j之间的字符组成。</P><P> </P><P>对于非负下标,如果下标都在界内,则片段的长度为下标的差。例如,word[1:3] 的长度为 2。</P><P> 内置函数len()返回字符串的长度:</P><PRE>&gt;&gt;&gt; s = 'supercalifragilisticexpialidocious'&gt;&gt;&gt; len(s)34&gt;&gt;&gt;</PRE><P>多行的长字符串也可以用行尾反斜杠续行,续行的行首空白不被忽略,如</P><PRE>        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.\n"        print hello</PRE><P>结果为</P><P> </P><PRE>        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.</PRE><P>对于特别长的字符串(比如包含说明的几段文字),如果用上面的方式每行都用\n\结尾是很麻烦的,特别是这样无法用象Emacs这样的功能强大的编辑器重新编排。对这种情况,可以使用三重撇号,例如</P><PRE>        hello = """             This string is bounded by triple double quotes (3 times ").        Unescaped newlines in the string are retained, though \        it is still possible\nto use all normal escape sequences.             Whitespace at the beginning of a line is        significant.  If you need to include three opening quotes        you have to escape at least one of them, e.g. \""".             This string ends in a newline.        """</PRE><P>三重撇号字符串也可以用三个单撇号,没有任何语义差别。</P><P>多行的字符串常量可以直接连接起来,字符串常量之间用空格分隔则在编译时可以自动连接起来,这样可以把一个长字符串连接起来而不需要牺牲缩进对齐或性能,不象用加号连接需要运算,也不象字符串串内的换行其行首空格需要保持。</P><H2>3.3 列表</H2><P>Python中有几种复合数据类型,用来把其它值组合到一起。其中最灵活的是列表,可以写成在方括号之间用逗号隔开的若干值(项)。列表的项不必取同一类型。</P><PRE>&gt;&gt;&gt; a = ['spam', 'eggs', 100, 1234]&gt;&gt;&gt; a['spam', 'eggs', 100, 1234]&gt;&gt;&gt;</PRE><P>象字符串下标那样,列表下标从0开始,列表可以取片段,可以连接,等等:</P><PRE>&gt;&gt;&gt; a[0]'spam'&gt;&gt;&gt; a[3]1234&gt;&gt;&gt; a[-2]100&gt;&gt;&gt; a[1:-1]['eggs', 100]&gt;&gt;&gt; a[:2] + ['bacon', 2*2]['spam', 'eggs', 'bacon', 4]&gt;&gt;&gt; 3*a[:3] + ['Boe!']['spam', 'eggs', 100, 'spam', 'eggs', 100, 'spam', 'eggs', 100, 'Boe!']&gt;&gt;&gt;</PRE><P>与字符串不同的是列表是可变的,可以修改列表的每个元素:</P><PRE>&gt;&gt;&gt; a['spam', 'eggs', 100, 1234]&gt;&gt;&gt; a[2] = a[2] + 23&gt;&gt;&gt; a['spam', 'eggs', 123, 1234]&gt;&gt;&gt;</PRE><P>也可以给一个片段重新赋值,这甚至可以改变表的大小:</P><PRE>&gt;&gt;&gt; # 替换若干项:... a[0:2] = [1, 12]&gt;&gt;&gt; a[1, 12, 123, 1234]&gt;&gt;&gt; # 去掉若干项:... a[0:2] = []&gt;&gt;&gt; a[123, 1234]&gt;&gt;&gt; # 插入若干项:... a[1:1] = ['bletch', 'xyzzy']&gt;&gt;&gt; a[123, 'bletch', 'xyzzy', 1234]&gt;&gt;&gt; a[:0] = a     # 在开头插入自身&gt;&gt;&gt; a[123, 'bletch', 'xyzzy', 1234, 123, 'bletch', 'xyzzy', 1234]&gt;&gt;&gt;</PRE><P>内置函数也使用于列表:</P><PRE>&gt;&gt;&gt; len(a)8&gt;&gt;&gt;</PRE><P>可以建立嵌套列表(表的元素也是列表),如:</P><PRE>&gt;&gt;&gt; q = [2, 3]&gt;&gt;&gt; p = [1, q, 4]&gt;&gt;&gt; len(p)3&gt;&gt;&gt; p[1][2, 3]&gt;&gt;&gt; p[1][0]2&gt;&gt;&gt; p[1].append('xtra')     # 列表方法&gt;&gt;&gt; p[1, [2, 3, 'xtra'], 4]&gt;&gt;&gt; q[2, 3, 'xtra']&gt;&gt;&gt;</PRE><P>注意这个例子中p[1]和q实际是同一个对象!也就是说它们只不过是同一个东西的两个名字(引用)而已。</P><H2>3.4  编程初步</H2><P>Python当然不是只能用来把两个数加到一起,它可以完成很复杂的工作。例如,我们可以写出Fibonacci序列的开始几个:</P><PRE>&gt;&gt;&gt; # Fibonacci 序列:... # 两个元素的和定义下一个... a, b = 0, 1&gt;&gt;&gt; while b &lt; 10:...       print b...       a, b = b, a+b... 112358&gt;&gt;&gt;</PRE><P>这个例子介绍了几个新特色。</P><P>第一行包含一个多重赋值: 变量a和b同时得到新值0和1。在最后一行又用了多重赋值,我们可以看出赋值时先把右边都算出后再进行赋值。</P><P>while循环当循环条件(这里即: b &lt; 10)成立时不断执行。在Python中和C中一样,非零整数值为真值,零为假值。条件也可以是字符串或列表或任何序列,长度为非零的为真,空序列为假。例子中所用的是一个简单比较。标准的比较算符和C一样:</P><PRE>&lt;, &gt;, ==, &lt;=, &gt;= 和 !=。</PRE><P>循环体是缩进的:缩进是Python用来组合语句的方式。Python目前还不能提供智能自动缩进,所以你需要自己为每个缩进行键入制表符或空格。实际使用中你可以用文本编辑程序为Python准备复杂的输入,多数文本编辑程序都有自动缩进的功能。在交互输入复合语句时必修附加一个空行以指示复合语句的完成(因为解释程序无法猜到哪是语句的最后一行)。print语句显示后面的表达式值。这和直接写出表达式不同,它可以显示多个表达式和字符串,而且可以用于程序文件中。显示时字符串没有撇号,各项目之间插入一个空格,所以你可以以精美的格式显示,如:</P><PRE>&gt;&gt;&gt; i = 256*256&gt;&gt;&gt; print 'The value of i is', iThe value of i is 65536&gt;&gt;&gt;</PRE><P>在尾部写一个逗号可以避免最后换行:</P><PRE>&gt;&gt;&gt; a, b = 0, 1&gt;&gt;&gt; while b &lt; 1000:...     print b,...     a, b = b, a+b... 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987&gt;&gt;&gt;</PRE><P>注意如果前一行没有结束的话系统在显示提示之前先换行。</P><P>Python还提供了和C语言一样的printf格式的输出方式,这是用%实现的,左边是格式,如:</P> <PRE>        &gt;&gt;&gt; print 'The value of 1/7 is approximately %5.3f.' % 0.142857        The value of 1/7 is approximately 0.143.        &gt;&gt;&gt;</PRE><P>如果有多个需要输出的项百分号右边的项可以是一个序组,如</P><PRE>        &gt;&gt;&gt; print "Name: %-10s  Age: %3d" % ("White", 31)        Name: White      Age:  31 </PRE></BODY><!-- Mirrored from www.math.pku.edu.cn/teachers/lidf/docs/Python/3.html by HTTrack Website Copier/3.x [XR&CO'2005], Fri, 08 Jul 2005 11:49:13 GMT --></HTML>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -