andyyuduo 发表于 2015-4-24 08:45:02

深入Python(二)

  变量声明
  Python 与大多数其它语言一样有局部变量和全局变量之分,但是它没有明显的变量声明。变量通过首次赋值产生,当超出作用范围时自动消亡。
  一次赋多值
  Python 中比较 “酷” 的一种编程简写是使用序列来一次给多个变量赋值
  
  >>> v = ('a', 'b', 'e')
  
  >>> (x, y, z) = v   
  
  >>> x
  
  'a'
  
  >>> y
  
  'b'
  
  >>> z
  
  'e'
  
  v 是一个三元素的 tuple,并且 (x, y, z) 是一个三变量的 tuple。将一个 tuple 赋值给另一个 tuple,会按顺序将 v 的每个值赋值给每个变量
  
  连续值赋值
  
  >>> (a,b,c,d)=range(4)
  >>> a
  0
  >>> b
  1
  >>> c
  2
  >>> d
  3
  内置的 range 函数返回一个元素为整数的 list。这个函数的简化调用形式是接收一个上限值,然后返回一个初始值从 0 开始的 list,它依次递增,直到但不包含上限值。
  如果您愿意,您可以传入其它的参数来指定一个非 0 的初始值和非 1 的步长
  >>> (a,b,c,d)=range(2,9,2)
  >>> a
  2
  >>> b
  4
  >>> c
  6
  >>> d
  8
  一定要确保range返回的list里的元素数量大于等于变量元组里的元素数量
  

  格式化字符串
  在 Python 中,字符串格式化使用与 C 中 printf 函数一样的语法
  字符串格式化不只是连接。它甚至不仅仅是格式化。它也是强制类型转换
  >>> uid = "sa"
  >>> pwd = "secret"
  >>> print pwd + " is not a good password for " + uid      
  secret is not a good password for sa
  >>> print "%s is not a good password for %s" % (pwd, uid)
  secret is not a good password for sa
  >>> userCount = 6
  >>> print "Users connected: %d" % (userCount, )       字符串格式化通过将 %s 替换成 %d 即可处理整数      
  Users connected: 6
  >>> print "Users connected: " + userCount               
  Traceback (innermost last):
  File "", line 1, in ?
  TypeError: cannot concatenate 'str' and 'int' objects
  数值的格式化
  >>> print "Today's stock price: %f" % 50.4625   
  50.462500
  >>> print "Today's stock price: %.2f" % 50.4625
  50.46
  >>> print "Change since yesterday: %+.2f" % 1.5
  +1.50
  %f 格式符选项对应一个十进制浮点数,不指定精度时打印 6 位小数。
  使用包含“.2”精度修正符的 %f 格式符选项将只打印 2 位小数。
  添加 + 修正符用于在数值之前显示一个正号或负号。注意“.2”精度修正符仍旧在它原来的位置,用于只打印 2 位小数。
  

  映射list
  >>> li =
  >>>       
  
  Python 循环遍历 li 中的每个元素。对每个元素均执行如下操作:首先临时将其值赋给变量 elem,然后 Python 应用函数 elem*2 进行计算,最后将计算结果追加到要返回的 list 中,Python 会在内存中创建新的 list,当对 list 的解析完成时,Python 将结果赋给变量。此理中原li不会受到影响。
  Dictionary 的keys, values 和 items 函数
  >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
  >>> params.keys()      Dictionary 的 keys 方法返回一个包含所有键的 list      这个 list 没按 dictionary 定义的顺序输出 (记住,元素在 dictionary 中是无序的)
  ['server', 'uid', 'database', 'pwd']
  >>> params.values()   values 方法返回一个包含所有值的 list
  ['mpilgrim', 'sa', 'master', 'secret']
  >>> params.items()      items 方法返回一个由形如 (key,value) 组成的 tuple 的 list
  [('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')]
  

  >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
  >>> params.items()
  [('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')]
  >>>                
  ['server', 'uid', 'database', 'pwd']
  >>>                
  ['mpilgrim', 'sa', 'master', 'secret']
  >>> ["%s=%s" % (k, v) for k, v in params.items()]
  ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
  请注意我们正在使用两个变量对 list params.items() 进行遍历。这是多变量赋值的另一种用法。
  params.items() 的第一个元素是 ('server', 'mpilgrim'),所以在 list 解析的第一次遍历中,k 将为 'server',v 将为 'mpilgrim'。在本例中,我们忽略了返回 list 中 v 的值,而只包含了 k 的值,所以这个 list 解析最后等于 params.keys()。
  
  连接list与分割字符串
  >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
  >>> ["%s=%s" % (k, v) for k, v in params.items()]
  ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
  >>> ";".join(["%s=%s" % (k, v) for k, v in params.items()])
  'server=mpilgrim;uid=sa;database=master;pwd=secret'
  join 方法将 list 中的元素连接成单个字符串,每个元素用一个分号隔开。join 只能用于元素是字符串的 list;它不进行任何的强制类型转换。连接一个存在一个或多个非字符串元素的 list 将引发一个异常。
  >>>s='server=mpilgrim;uid=sa;database=master;pwd=secret'
  >>> s.split(";")
  ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
  split 与 join 正好相反,它将一个字符串分割成多元素 list
  split 接受一个可选的第二个参数,它是要分割的次数
  
  >>> s.split(";", 1)
  
  ['server=mpilgrim', 'uid=sa;database=master;pwd=secret']
  
  
页: [1]
查看完整版本: 深入Python(二)