Example 2.1. odbchelper.py

def buildConnectionString(params):
    """Build a connection string from a dictionary

    Returns string."""
    return ";".join(["%s=%s" % (k, v) for k, v in params.items()])

if __name__ == "__main__":
    myParams = {"server":"mpilgrim", \
	    "database":"master", \
	    "uid":"sa", \
	    "pwd":"secret"
	    }
    print buildConnectionString(myParams)

odbchelper.py的输出结果:

pwd=secret;database=master;uid=sa;server=mpilgrim

1、函数声明

Python里的函数不需要指定返回值的数据类型,甚至不需要指定是否有返回值。实际上,每个Python函数都会返回一个值:如果函数执行过return语句,它将返回指定的值,否则将返回None(Python的空值)。

2、文档化函数

可以通过给出一个doc string(文档字符串)来文档化一个Python函数。

def buildConnectionString(params):
    """Build a connection string from a dictionary

    Returns string."""

三重引号表示一个多行字符串。在开始与结束引号之间的所有东西都被视为单个字符串的一部分,包括硬回车和其它的引号字符。在三重引号中的任何东西都是这个函数的doc string,它们用来说明函数可以做什么。如果存在doc string,它必须是一个函数要定义的第一个内容(也就是说,在冒号后面的第一个内容)。

3、万物皆对象

在Python中一切都是对象,并且几乎一切都有属性(看上去是什么样)和方法(会做什么)。万物皆对象可以感性地解释为:一切都可以赋值给变量或者作为参数传递给函数。

4、测试模块

所有的Python模块都是对象,并且都有一个内置属性__name__。一个模块的__name__的值取决于你如何应用模块:

如果import模块,那么__name__的值通常为模块的文件名,不带路径和文件扩展名。

>>>import odbchelper
>>>odbchelper.__name__
'odbchelper'

而如果直接运行模块,__name__的值将是一个特别的缺省值(即默认值),__main__。

可以利用这一特性在模块内部设计一个测试套件:

if __name__=="__main__":

当直接运行模块时,__name__的值是__main__,所以测试套件执行。而导入模块时,__name__的值就是别的东西了,所以测试套件被忽略。这样使得在将新的模块集成到一个大程序之前开发和调试容易多了。

5、字典(Dictionary)

>>>d = {"server":"mpilgrim","database":"master"}       (1)
>>>d
 {'server':'mpilgrim','database':'master'}
>>>d["server"]                                         (2)
'mpilgrim'
>>>d["database"]
'master'
>>>d{"mpilgrim"}                                       (3)
Traceback (innermost last):
  File"<interractive input>",line 1, in ?
KeyError: mpilgrim
>>>d["datebase"] = "pubs"                              (4)
>>>d
{'server':'mpilgrim','database':'pubs'}
>>>d["uid"] = "sa"                                     (5)
>>>d
{'server':'mpilgrim','uid':'sa','database':'pubs'}

(1)创建一个新的字典,它有两个元素,将其赋给变量d。每一个元素都是一个key—value对;整个元素集合用大括号括起来。

(2)’server’是一个key,它所关联的value是通过d[“server”]来引用的,为‘mpilgrim’。

(3)可以通过key来引用其值,但不能通过值获取key。

(4)在一个dictionary中不能有重复的key。给一个存在的key赋值会覆盖原有的值。

(5)1、在任何时候都可以加入新的key—value对。2、dictionary是无序的。

dictionary的key是大小写敏感的(即区分大小写)。

dictionary不止是用于存储字符串。它的值可以是任意数据类型,包括字符串、整数、对象,甚至其他的dictionary。在单个dictionary里,它的值不需要全都是同一数据类型,可以根据需要混用和匹配。dictionary的key则要严格的多。

del dictionary[key] 使用key从一个dictionary中删除独立的元素。

dictionary.clear()清除dictionary中的所有元素。

6、列表(List)

list中的元素是有序的,并且不必唯一。

append(追加)接受一个参数(这个参数可以是任何数据类型),并且简单地追加到list尾部。而extend(扩展)接受一个参数,这个参数总是一个list,并且把这个list中的每个元素添加到原list中。

insert将单个元素插入到list中。数值参数是插入点的索引。

index在list中查找一个值的首次出现并返回索引值。如果在list中没有找到值,python会引发一个异常。

要测试一个值是否在list中,使用in。如果值存在,它返回True,否则返回False。True和False的首字母必须大写。

remove从list中删除一个值的首次出现。如果没有找到该值,python同样会返回一个异常。

pop会删除list的最后一个元素,然后返回删除元素的值。

list可以用 + 运算符连接起来。list = list + otherlist相当于list。extend(otherlist)。

li += [‘two’]等同于li.extend([‘two’]).

* 运算符可以作为重复器作用于list。li = li * 3即把三个list连接成一个。

7、元组(Tuple)

Tuple是不可改变的list。一旦创建了一个tuple,就不能以任何方式改变它。

定义tuple与定义list的方式相同,但整个元素集是用小括号包围的,而不是方括号。

tuple的元素与list一样按定义的次序进行排序。

tuple没有方法,但可以使用in来查看一个元素是否存在于tuple中。

使用tuple的好处:

  • tuple比list操作速度快,如果定义了一个值的常量集,并且唯一要用它做的是不断遍历它,应该使用tuple代替list。
  • 如果对不需要修改的数据进行“写保护”,可以使代码更安全。
  • tuple可以在dictionary中被用做key,但list不行。Dictionary key必须是不可变的。
  • tuple可以用在字符串格式化中。

8、变量声明

当一条命令用续行符(“\”)分割成多行时,后续的行可以以任意方式缩进。

一次赋多值

>>> v = ('a','b','e')
>>> (x,y,z) = V
>>> x
'a'
>>>y
'b
>>>z
'e'

v是一个三元素的tuple,并且(x,y,z)是一个三变量的tuple。将一个tuple赋值给另一个tuple,会按顺序将v的每个值赋给每个变量。

连续值赋值

>>>range(7)
[0,1,2,3,4,5,6]
>>>(MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY,SATURDAY,SUNDAY) = range(7)
>>>MONDAY
0
>>>TUESDAY
1
>>>SUNDAY
6

内置的range函数返回一个元素为整数的list。

9、格式化字符串

字符串的格式化

>>> uid = "sa"
>>> pwd = "se cret"
>>> print pwd + " isnot agood passwor d for " + uid       (1)
secret is not agoodpasswo rd for sa
>>> print "%s is nota good passw ord for %s" % (pw d,uid) (2)
secretis not agood passwo rd for sa
>>> userCou nt = 6
>>> print "Users con nected: %d" %(use rCoun t, )         (3) (4)
Users connected:6
>>> print "Users con nected: " + userCoun t               (5)
Traceback (innermost last) :
File "<i nteract ive input>", line 1, in ?
TypeError: cannot concatenate 'str'and 'int' objects

(1)通过连接操作符“+”连接

(2)通过字符串格式化实现连接

(3)(userCount,)是一个只包含一个元素的tuple。当定义一个list,tuple,dictionary时,可以总是在最后一个元素后面跟上一个逗号,但是当定义一个只包含一个元素的tuple时逗号是必须的。如果省略逗号,python不会知道(userCount)究竟是一个只包含一个元素的tuple还是变量userCount的值。

(4)字符串格式化通过将%s替换成%d即可处理整数。

(5)试图将一个字符串同一个非字符串连接会引发一个异常。字符串连接只能在被连接的每一个都是字符串时起作用。

数值的格式化

>>> print "Today's stock price: %f" %50.4625   (1)
50.462500
>>> print "Today's stock price: %.2f" %50.4625 (2)
50.46
>>> print "Change since yesterday: %+.2f" %1.5 (3)
+1.50

(1)%f格式符选项对应一个十进制浮点数,不指定精度时打印6位小数。

(2)使用包含“.2”精度修正符的%f格式符选项将只打印2位小数。

(3)添加+修正符用于在数值之前显示一个正号或负号。

10、映射list

通过对list中的每个元素应用一个函数,从而将一个list映射为另一个list

>>> li = [1, 9,8, 4]
>>> [elem*2 for elem in li]        (1)
[2, 18, 16, 8]
>>> li                             (2)
[1, 9, 8, 4]
>>> li = [ elem*2 for elem in li]  (3)
>>> li
[2, 18, 16, 8]

(1)li是一个将要映射的list。Python循环遍历li中的每个元素。对每个元素均执行如下操作:首先临时将其值赋给变量elem,然后Python应用函数elem*2进行计算,最后将结果追加到要返回的list中。

(2)对list的解析并不改变原始的list。

(3)将一个list的解析结果赋值给对其映射的变量是安全的。

keys、values和items函数

>>> params = {"server":"mpilgrim", "database":"master", "uid":"sa",  "pwd":"secret"}
>>> params .keys()   (1)
['server', 'uid', 'database' , 'pwd']
>>> params .values() (2)
['mpilgrim', 'sa', 'master', 'secret']
>>> params .items()  (3)
[('server', 'mpilgrim'), ('uid', 'sa'), ('database' , 'master'), ('pwd' , 'secret')]

(1)dictionary的keys方法返回一个包含所有键的list。这个list没按dictionary定义的顺序输出(因为dictionary中的元素是无序的)。

(2)values方法返回一个包含所有值的list。它同keys返回的list输出顺序相同。

(3)items函数返回一个形如(key,value)组成的tuple的list,这个list包括dictionary中所有的数据。

11、连接list与分割字符串

连接list

return ";".join(["%s=%s" % (k, v) f or k, v i nparams. items()])

字符串”;”本身就是一个对象,而调用join方法是将list中的元素连接成单个字符串,每个元素用一个分号隔开。分隔符不必是一个分号,它甚至不必是单个字符,它可以是任何字符串。

join只能用于元素是字符串的list,它不进行任何的强制类型转换。连接一个存在一个或多个非字符串元素的list将引发一个异常。

分割字符串

>>> li = ['se rver=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
>>> s = ";".join(li)
>>> s
'server=mpilgrim;uid=sa;database=master;pwd=secret'
>>> s.split(";")     (1)
['server=mpilgrim', 'uid=sa', 'datab ase=master', 'pwd=secret']
>>> s.split(";", 1)  (2)
['server=mpilgrim', 'uid=sa;datab ase=master;pwd=secret']

(1)与join相反,split将一个字符串分割成多元素list。其中,分隔符被完全去掉了。

(2)split接受一个可选的第二参数,它是要分割的次数。

《Dive into Python》Chapter 2 and Chapter 3 笔记的更多相关文章

  1. 为什么《Dive into Python》不值得推荐

    2010 年 5 月 5 日更新:我翻译了一篇<<Dive Into Python>非死不可>作为对本文观点的进一步支持和对评论的回复,请见:http://blog.csdn. ...

  2. python 学习笔记 5 ----> dive into python 3

    字符串 文本:屏幕上显示的字符或者其他的记号 计算机认识的东西:位(bit)和字节(byte) 文本的本质:某种字符编码方式保存的内容. 字符编码:一种映射(显示的内容  ----> 内存.磁盘 ...

  3. python 学习笔记 4 ----> dive into python 3

    解析 列表解析.字典解析.集合解析 浏览本地文件系统的模块: 1 os 2 os.path 3 glob os模块:获取(和修改)本地目录.文件进程.环境变量等信息 os.path模块:包含了操作路径 ...

  4. python 学习笔记 3 ----> dive into python 3

    Python内置数据类型 注意: Python可以不需要声明变量的数据类型.它是根据变量的初始赋值情况分析数据类型,并在内部跟踪变量. 比较重要的数据类型: 1 布尔型(Booleans):True. ...

  5. python 学习笔记 2 ----> dive into python 3

    Python Shell idle的使用 >>> >>>help() ----> help> 可以在help这个工具中查找Python内置函数的文档等等 ...

  6. Dive into Python

    写这篇文章的原因完全是为了督促自己每天晚上看完两章<Dive Into Python>这本书,因此,很多内容都是摘抄自原书的翻译版或者是自己瞎想,于是就顺带着记录了下来.此前已经看完前两章 ...

  7. Python编程从入门到实践笔记——异常和存储数据

    Python编程从入门到实践笔记——异常和存储数据 #coding=gbk #Python编程从入门到实践笔记——异常和存储数据 #10.3异常 #Python使用被称为异常的特殊对象来管理程序执行期 ...

  8. Python编程从入门到实践笔记——文件

    Python编程从入门到实践笔记——文件 #coding=gbk #Python编程从入门到实践笔记——文件 #10.1从文件中读取数据 #1.读取整个文件 file_name = 'pi_digit ...

  9. Python编程从入门到实践笔记——类

    Python编程从入门到实践笔记——类 #coding=gbk #Python编程从入门到实践笔记——类 #9.1创建和使用类 #1.创建Dog类 class Dog():#类名首字母大写 " ...

  10. Python编程从入门到实践笔记——函数

    Python编程从入门到实践笔记——函数 #coding=gbk #Python编程从入门到实践笔记——函数 #8.1定义函数 def 函数名(形参): # [缩进]注释+函数体 #1.向函数传递信息 ...

随机推荐

  1. ASP.NET Ajax简单的无刷新分页

    最近练习了一些AJAX无刷新分页,写得比较简单,性能不知道怎么样,求大神指点,如有更好的分页提供,欢迎交流! 发话不多说了,直接上代码! 首先从网上下了一个JS分页,感觉挺好用的 (function( ...

  2. PHP分页

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. PAT1015—— 德才论

    宋代史学家司马光在<资治通鉴>中有一段著名的“德才论”:“是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人.凡取人之术,苟不得圣人,君子而与之,与其得小人,不若得愚人 ...

  4. dispatch_async 子线程,主线程的简单用法

    子线程的使用方法: dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, ), ^{ //子线程的处理逻辑 ...

  5. 经典算法系列--kmp

    前言 之前对kmp算法虽然了解它的原理,即求出P0···Pi的最大相同前后缀长度k:但是问题在于如何求出这个最大前后缀长度呢?我觉得网上很多帖子都说的不是很清楚,总感觉没有把那层纸戳破,后来翻看算法导 ...

  6. Matlab摄像头标定得出的参数保存为xml

    最近在做双摄像头的立体匹配,发现OpenCV定标效果不如MatLab的效果,于是用MatLab标定箱做标定,将得到的结果保存为xml,然后,提供给opencv使用.MatLab标定箱做标定得到的结果如 ...

  7. ajax学习计划

    来自http://segmentfault.com/a/1190000004322487?utm_source=Weibo&utm_medium=shareLink&utm_campa ...

  8. JS函数式编程【译】第二章总结

  9. Java 和 Javascript 的 Date 与 .Net 的 DateTime 之间的相互转换

    Java 和 Javascript 的 Date 对象内部存放的是从1970年1月1日0点以来的毫秒值. .Net 的 DateTime 对象内部存放的是从0001年1月1日12点以来的tick值,1 ...

  10. DataGrid1

    2013-09-2512:26:31 1.DataGrid页面 <asp:DataGrid ID="msgInfo1" PageSize="8" Auto ...