设为首页 收藏本站
查看: 1120|回复: 0

[经验分享] 深入Python(二)

[复制链接]

尚未签到

发表于 2015-4-24 08:45:02 | 显示全部楼层 |阅读模式
  变量声明
  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 = [1, 9, 8, 4]
  >>> [elem*2 for elem in li]      
  [2, 18, 16, 8]
  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 方法返回一个由形如 (keyvalue) 组成的 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')]
  >>> [k for k, v in params.items()]               
  ['server', 'uid', 'database', 'pwd']
  >>> [v for k, v in params.items()]               
  ['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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-60143-1-1.html 上篇帖子: python使用SUDS调用webservice 下篇帖子: 【python】【scrapy】使用方法概要(三)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表