Extend and append
- extend的參數(shù)只能是list類型,它負(fù)責(zé)將一個(gè)list添加到另一個(gè)List之后。append的參數(shù)可以是任意類型,它將參數(shù)作為一個(gè)整體添加到List之后
Join()
把一個(gè)list中所有的串按照你定義的分隔符連接起來(lái)
import string list=['abc','cde','jhjh'] sep = '|' string.join(list,sep) 'abc|cde|jhjh'
或者
str = 'goujinping' ','.join(str) 'g,o,u,j,i,n,p,i,n,g'
Split()
split用法示例
b = 'my..name..is..bob' b.split() ['my..name..is..bob'] b.split("..") ['my', 'name', 'is', 'bob'] b.split("..",0) ['my..name..is..bob'] b.split("..",1) ['my', 'name..is..bob'] b.split("..",2) ['my', 'name', 'is..bob'] b.split("..",-1) ['my', 'name', 'is', 'bob']
可以看出 b.split("..",-1)等價(jià)于b.split("..")
Defaultdict
http://kodango.com/understand-defaultdict-in-python
sorted()
sorted(2,1,4) 是錯(cuò)的!要加小括號(hào)或中括號(hào)
sorted((2,1,4)) -> [1,2,4]
最大最小整數(shù)
python中最大整數(shù):MAX_INT = 2147483647 = 2**31-1
最小整數(shù):MIN_INT = -2147483648 = -2**31
ord(),chr()
- ord()函數(shù)是chr()函數(shù)(對(duì)于8位的ASCII字符串)或unichr()函數(shù)(對(duì)于Unicode對(duì)象)的配對(duì)函數(shù),它以一個(gè)字符(長(zhǎng)度為1的字符串)作為參數(shù),返回對(duì)應(yīng)的ASCII數(shù)值
- chr()函數(shù)用一個(gè)范圍在range(256)內(nèi)的(就是0~255)整數(shù)作參數(shù),返回一個(gè)對(duì)應(yīng)的字符。
str.strip()
去掉str前后空格
list = [80, 443, 8080, 8081]
print str(list).strip('[]')
80, 443, 8080, 8081

/與%
321/1 = 321 取前三位 321/10 = 32 取前兩位 321 /100 = 3 取第一位
321%100 = 21取后兩位 321%10 = 1取后一位 321%1 = 0
num / 1000 取四位數(shù)的第1個(gè)數(shù)字
(num % 1000) /100 取四位數(shù)的第2個(gè)數(shù)字
(num % 100) / 10 取四位數(shù)的3個(gè)數(shù)字
num % 10 取四位數(shù)的第4個(gè)數(shù)字
str.replace()
Python replace() 方法把字符串中的 old(舊字符串) 替換成 new(新字符串),如果指定第三個(gè)參數(shù)max,則替換不超過(guò) max 次。
str.replace(old, new[, max])
zfill()
python中有一個(gè)zfill方法用來(lái)給字符串前面補(bǔ)0,非常有用
n = "123"
s = n.zfill(5)
assert s == "00123"
zfill()也可以給負(fù)數(shù)補(bǔ)0
n = "-123"
s = n.zfill(5)
assert s == "-0123"
對(duì)于純數(shù)字,我們也可以通過(guò)格式化的方式來(lái)補(bǔ)0
n = 123
s = "%05d" % n
assert s == "00123"
python格式字符串
http://blog.xiayf.cn/2013/01/26/python-string-format/
map()
https://my.oschina.net/zyzzy/blog/115096
int('110', 2)
將以2進(jìn)制表示的110轉(zhuǎn)換為整數(shù)十進(jìn)制,6
進(jìn)制轉(zhuǎn)換

除十進(jìn)制外,均帶有前綴,所以取切片a[2:]
列表與字符串的相互轉(zhuǎn)換
list = ['1','2','3','4']
list to string: ''.join(list) 輸出'1234',不改變?cè)瓉?lái)的list結(jié)構(gòu),注意這里L(fēng)ist的元素是字符型,如果是整數(shù)形式就只能用while循環(huán)一個(gè)一個(gè)的轉(zhuǎn)換類型再連接起來(lái)
string = '1,2,3,4' 注意元素之間有逗號(hào)
string to list: string.split(' ,') , 得到['1', '2', '3', '4'] 注意:split括號(hào)里的參數(shù)應(yīng)當(dāng)時(shí)字符形式,如果沒(méi)有參數(shù),則只把字符串作為一個(gè)整體存入數(shù)組里,所以數(shù)組里僅有一個(gè)元素。split更多的含義是按傳進(jìn)去的字符參數(shù)將string分開,但是分開后是以數(shù)組的形式存在的,并且不改變?cè)瓉?lái)的string
string to list還可以用map:
string = '1234'
list = map(int, string) = [1,2,3,4] 也不改變string原來(lái)的結(jié)構(gòu)
還是map更方便一些,不需要字符串中一定有連接字符之類的東西
刪除列表中符合條件的元素

去除列表中的重復(fù)元素
a = [11,22,33,44,11,22]
b = set(a)
print b
set([33, 11, 44, 22])
c = [i for i in b]
print c
[33, 11, 44, 22]
sorted(key)

operator模塊有itemgetter,attrgetter
from operator import itemgetter, attrgetter
sorted(student_tuples, key=itemgetter(2))
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]
sorted(student_objects, key=attrgetter('age'))
[('dave', 'B', 10), ('jane', 'B', 12), ('john', 'A', 15)]operator模塊還允許多級(jí)的排序,例如,先以grade,然后再以age來(lái)排序:
復(fù)制代碼代碼如下:
sorted(student_tuples, key=itemgetter(1,2))
[('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]
sorted(student_objects, key=attrgetter('grade', 'age'))
[('john', 'A', 15), ('dave', 'B', 10), ('jane', 'B', 12)]list.sort()和sorted()都接受一個(gè)參數(shù)reverse(True or False)來(lái)表示升序或降序排序。例如對(duì)上面的student降序排序如下:
sorted(student_tuples, key=itemgetter(2), reverse=True)
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
sorted(student_objects, key=attrgetter('age'), reverse=True)
[('john', 'A', 15), ('jane', 'B', 12), ('dave', 'B', 10)]
從python2.2開始,排序被保證為穩(wěn)定的。意思是說(shuō)多個(gè)元素如果有相同的key,則排序前后他們的先后順序不變。
多級(jí)排序方法:
用cmp:
Compare the two objects x and y and return an integer according to the outcome. The return value is negative if x < y, zero if x == y and strictly positive if x > y.
list.sort(cmp = compare(x['name']))
python3已經(jīng)去掉了cmp,cmp可以自定義, cmp函數(shù)如果是對(duì)整體排序,就不需要傳參數(shù),如果是對(duì)某一項(xiàng)排序,就需要傳遞參數(shù)進(jìn)去用key
list.sort(key = lambda x: x[1])
list.sort(key = lambda x, y: x["price"] - y["price"])
from operator import itemgetter, attrgetter
list.sort(key = itemgetter("price"))
list.sort(key = itemgetter(0, 1))
list.sort(key = itemgetter(*args))
格式化輸出
%02d 數(shù)字轉(zhuǎn)成兩位整型缺位填0
https://xshell.net/python/1305.html
Lambda
當(dāng)list中的項(xiàng)目為自定義格式時(shí),想要對(duì)list進(jìn)行排序:
intervals.sort(key = lambda x: x.start).
以x.start為標(biāo)準(zhǔn)對(duì)每個(gè)inter進(jìn)行排序
初始化二維數(shù)組
res = [[0 for i in range(n)] for i in range(n)]
ZIP
zip()是Python的一個(gè)內(nèi)建函數(shù),它接受一系列可迭代的對(duì)象作為參數(shù),將對(duì)象中對(duì)應(yīng)的元素打包成一個(gè)個(gè)tuple(元組),然后返回由這些tuples組成的list(列表)。若傳入?yún)?shù)的長(zhǎng)度不等,則返回list的長(zhǎng)度和參數(shù)中長(zhǎng)度最短的對(duì)象相同。利用號(hào)操作符,可以將list unzip(解壓),看下面的例子就明白了:
a = [1,2,3]
b = [4,5,6]
c = [4,5,6,7,8]
zipped = zip(a,b): [(1, 4), (2, 5), (3, 6)]
zip(a,c): [(1, 4), (2, 5), (3, 6)]
zip(zipped): [(1, 2, 3), (4, 5, 6)]
二維矩陣變換(矩陣的行列互換)
比如我們有一個(gè)由列表描述的二維矩陣
a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
通過(guò)python列表推導(dǎo)的方法,我們也能輕易完成這個(gè)任務(wù)
print [ [row[col] for row in a] for col in range(len(a[0]))]
[[1, 4, 7], [2, 5, 8], [3, 6, 9]]
另外一種讓人困惑的方法就是利用zip函數(shù):
a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
zip(a)
[(1, 4, 7), (2, 5, 8), (3, 6, 9)]
map(list,zip(a))
[[1, 4, 7], [2, 5, 8], [3, 6, 9]]
collections.deque()

正無(wú)窮與負(fù)無(wú)窮
float('inf), float('-inf')
For-Else 循環(huán)
https://segmentfault.com/a/1190000004903355
for循環(huán)如果是正常退出,才會(huì)執(zhí)行else, 如果是因?yàn)閎reak退出,就不會(huì)執(zhí)行else
try-except finally
https://docs.python.org/2/tutorial/errors.html