流畅的python和cookbook学习笔记(一)

1.数据结构

1.1 内置序列类型

  四种序列类型:

  1.容器序列:list、tuple和collections.deque

  2.扁平序列:str、bytes、bytearray、memoryview和array.array

  3.可变序列:list、bytearray、array.array、collections.deque 和 memoryview

  4.不可变序列:tuple、str 和 bytes

1.2 列表推导

  1.列表推导(list comprehension):列表推导是构建列表(list)的快捷方式,简洁的写法。

  列表推导的作用只有一个:生成列表。

>>> symbols = ‘$¢£¥€¤‘
>>> codes = [ord(symbol) for symbol in symbols] # 用方括号括起来,内部用for循环生成多个值
>>> codes
[36, 162, 163, 165, 8364, 164]

  2.表达式内部的变量和赋值只在局部起作用,表达式的上下文里的同名变量还可以被正常引用,局部变量并不会影响到它们。

>>> x = ‘ABC‘
>>> dummy = [ord(x) for x in x]
>>> x
‘ABC‘
>>> dummy
[65, 66, 67]

  即 x 的值不会被列表推导中的循环中的 x 值所影响。

1.3 生成器表达式

  1.生成式表达器(generator expression):生成器表达式遵守了迭代器协议,可以逐个地产出元素,而不是先建立一个完整的列表,然后再把这个列表传递到某个构造函数里。这样更节省内存。

  生成器表达式的语法跟列表推导差不多,只不过把方括号换成圆括号而已。

  用生成器表达式初始化元组和数组:

>>> symbols = ‘$¢£¥€¤‘ # 初始化元组
>>> tuple(ord(symbol) for symbol in symbols) # 如果生成器表达式是一个函数调用过程中的唯一参数,那么不需要额外再用括号把它围起来。
(36, 162, 163, 165, 8364, 164)
>>> import array # 初始化数组
>>> array.array(‘I‘, (ord(symbol) for symbol in symbols)) # array 的构造方法需要两个参数,因此括号是必需的。array 构造方法的第一个参数,即(‘I‘)指定了数组中数字的存储方式。
array(‘I‘, [36, 162, 163, 165, 8364, 164])

1.4 笛卡尔积 

  笛卡儿积是一个列表,列表里的元素是由输入的可迭代类型的元素对构成的元组,因此笛卡儿积列表的长度等于输入变量的长度的乘积。

  1.使用列表推导计算笛卡儿积

>>> colors = [‘black‘, ‘white‘]
>>> sizes = [‘S‘, ‘M‘, ‘L‘]
>>> tshirts = [(color, size) for color in colors for size in sizes]
>>> tshirts [(‘black‘, ‘S‘), (‘black‘, ‘M‘), (‘black‘, ‘L‘), (‘white‘, ‘S‘), (‘white‘, ‘M‘), (‘white‘, ‘L‘)]
>>> for color in colors:  # 使用for循环是一样的效果
...        for size in sizes:
...            print((color, size))
...
(‘black‘, ‘S‘)
(‘black‘, ‘M‘)
(‘black‘, ‘L‘)
(‘white‘, ‘S‘)
(‘white‘, ‘M‘)
(‘white‘, ‘L‘)
>>> tshirts = [(color, size) for size in sizes for color in colors]  # 改变参数位置,输出顺序不同
>>> tshirts
[(‘black‘, ‘S‘), (‘white‘, ‘S‘), (‘black‘, ‘M‘), (‘white‘, ‘M‘), (‘black‘, ‘L‘), (‘white‘, ‘L‘)]

  2.使用生成器表达式计算笛卡儿积

>>> colors = [‘black‘, ‘white‘]
>>> sizes = [‘S‘, ‘M‘, ‘L‘]
>>> for tshirt in (‘{} {}‘.format(c, s) for c in colors for s in sizes):
...     print(tshirt)
...
black S
black M
black L
white S
white M
white L
时间: 08-24

流畅的python和cookbook学习笔记(一)的相关文章

流畅的python和cookbook学习笔记(五)

1.随机选择 python中生成随机数使用random模块. 1.从序列中随机挑选元素,使用random.choice() >>> import random >>> values = [1, 2, 3, 4, 5, 6] >>> random.choice(values) 3 >>> random.choice(values) 3 >>> random.choice(values) 1 >>> r

流畅的python和cookbook学习笔记(六)

1.同时迭代多个序列(zip(函数)) 使用zip()函数可以同时迭代多个序列. >>> X = [1, 2, 3, 4, 5, 6] >>> Y = [121, 223, 116, 666, 919, 2333] >>> for x, y in zip(X, Y): ... print(x, y) ... 1 121 2 223 3 116 4 666 5 919 6 2333 zip(a, b)的作用是创建一个迭代器,产生元组(x, y),x取自a

流畅的python和cookbook学习笔记(八)

1.函数的默认参数必须不可变 如果函数的默认参数为可变的对象,那么默认参数在函数外被修改也会影响到函数本身的. >>> def spam(a, b=None): # b要为不可变参数,不能使用空列表 [] 等可变参数 ... if b is None: ... b = [] ... 2.匿名函数 1.想不出函数名时,或想要一种短小的操作,可以使用匿名函数 >>> sum = lambda x, y: x + y >>> sum(2, 3) 5 >

流畅的python和cookbook学习笔记(三)

1.双向队列 collections.deque 类(双向队列)是一个线程安全.可以快速从两端添加或者删除元素的数据类型. rotate和popleft操作,rorate可以把前后元素换位.popleft可以从左边删除元素,extendleft可以从左边添加元素. >>> from collections import deque # 导入deque模块 >>> dq = deque(range(10), maxlen=10) # deque可以有maxlen参数,限制

流畅的python和cookbook学习笔记(二)

1.元组拆包和解压序列赋值 任何的序列 (或者是可迭代对象) 可以通过一个简单的赋值语句解压并赋值给多个 变量.唯一的前提就是变量的数量必须跟序列元素的数量是一样的. 1.平行赋值: >>> x = (1, 2) >>> a, b = x # 元组拆包 >>> a 1 >>> b 2 2.以用 * 运算符把一个可迭代对象拆开作为函数的参数: >>> divmod(20, 8) # 20求8的余,2 * 8 + 4 =

Mysql Cookbook学习笔记第二章

1,使用python链接mysql + ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 # -*- coding: utf-8 -*- # connect.py --连接到MySQL服务器 import sys import MySQLdb try:     conn = MySQLdb.connect(db = "cookbook",                            host = "localhost"

python网络爬虫学习笔记

python网络爬虫学习笔记 By 钟桓 9月 4 2014 更新日期:9月 4 2014 文章目录 1. 介绍: 2. 从简单语句中开始: 3. 传送数据给服务器 4. HTTP头-描述数据的数据 5. 异常 5.0.1. URLError 5.0.2. HTTPError 5.0.3. 处理异常 5.0.4. info和geturl 6. Opener和Handler 7. Basic Authentication 8. 代理 9. Timeout 设置 10. Cookie 11. Deb

python数据分析入门学习笔记儿

学习利用python进行数据分析的笔记儿&下星期二内部交流会要讲的内容,一并分享给大家.博主粗心大意,有什么不对的地方欢迎指正~还有许多尚待完善的地方,待我一边学习一边完善~ 前言:各种和数据分析相关python库的介绍(前言1~4摘抄自<利用python进行数据分析>) 1.Numpy: Numpy是python科学计算的基础包,它提供以下功能(不限于此): (1)快速高效的多维数组对象naarray (2)用于对数组执行元素级计算以及直接对数组执行数学运算的函数 (3)用于读写硬盘

&lt;&lt;Python基础教程&gt;&gt;学习笔记之|第01章|基础知识

本学习笔记主要用要记录下学习<<Python基础教程>>过程中的一些Key Point,或自己没怎么搞明白的内容,可能有点杂乱,但比较实用,查找起来也方便. 第01章:基础知识 ------ Jython:      Python的Java实现,运行在JVM中,相对稳定,但落后于Python,当前版本2.5,在TA(Python+Robot)会用到 IronPython:  Python的C#实现,运行在Common Language Runtime,速度比Python要快 >