python程式設計之美

2021-08-07 21:37:51 字數 3833 閱讀 6027

許久沒有用python,好多都忘得差不多了,以至於面試**,趕緊複習,求下次輕虐。。。

1 cmp(list1, list2) 比較兩個列表的元素

2 len(list) 列表元素個數

3 max(list) 返回列表元素最大值

4 min(list) 返回列表元素最小值

5 list(seq) 將元組轉換為列表

2 list.count(obj) 統計某個元素在列表中出現的次數

3 list.extend(seq) 在列表末尾一次性追加另乙個序列中的多個值(用新列表擴充套件原來的列表)

4 list.index(obj) 從列表中找出某個值第乙個匹配項的索引位置

5 list.insert(index, obj) 將物件插入列表

6 list.pop(obj=list[-1]) 移除列表中的乙個元素(預設最後乙個元素),並且返回該元素的值

7 list.remove(obj) 移除列表中某個值的第乙個匹配項

8 list.reverse() 反向列表中元素

9 list.sort([func]) 對原列表進行排序

list1  = [1,2,3,4,5,6,7]

list2 = list1[:3]#0~3,但是不包含3,和c++stl中的迭代器有點像

list2

[1, 2, 3]
list2[0]
1
list2[2] = 0

list2

[1, 2, 0]
list1
[1, 2, 3, 4, 5, 6, 7]
list1[2] =10
list2
[1, 2, 0]
list1
[1, 2, 10, 4, 5, 6, 7]
list1[-5:-1]
[10, 4, 5, 6]
list1[-1]
7
list1[::2]
[1, 10, 5, 7]
for ch in

'abc':

print ch

a

bc

for i,j in [(1,2),(3,4),(5,6)]:

print i,j

1 2

3 45 6

#生成乙個列表

#方式一

import numpy as np

l =

for i in xrange(1,11):

#方式二,列表生成器

[x for x in range(1,11)]

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
加判斷語句
[x for x in xrange(1,11) if x % 2 == 0]
[2, 4, 6, 8, 10]
[x for x in np.random.random(10) if x < 0]
多層迴圈
[m + n for m in

'abc'

for n in

'xyz']

['ax', 'ay', 'az', 'bx', 'by', 'bz', 'cx', 'cy', 'cz']
gen = (x **2

for x in range(5))

gen
at 0x0000000004358798>
for n in gen:

print n

014

916

def

myfun

(): n = 1

while n < 10:

yield n

n = n + 2

genfun = myfun()

for n in genfun:

print n

135

79

abs(-5)
5
f= abs

f

f(-4)
4
l = [1,2,3,-4,-5,-1,-2]

sorted(l,key = f)#按絕對值進行排序

[1, -1, 2, -2, 3, -4, -5]
def

add1

(x, y,key = f):

return f(x) + f(y)

add1(1,-2,f)
3
l = [1,2,3,-4,-5]

map(abs,l)

[1, 2, 3, 4, 5]
import functools

addabs = functools.partial(add1,key = abs)#用偏函式固定引數

reduce(addabs,l)

15
filter(lambda x:x>0,l)
[1, 2, 3]
filter(function,obj),function返回ture或者flase,obj為乙個序列

sorted是高階函式,可以接受函式引數

sorted(l,key = abs)
[1, 2, 3, -4, -5]
from collections import iterator

l = [('bob', 75), ('adam', 92), ('bart', 66), ('lisa', 88)]

l = dict(l)

l#判斷是不是迭代器

isinstance(iter( l.keys()),iterator)

#生成迭代器 iter()函式

sorted(iter(l.keys()),key = str.lower)

['adam', 'bart', 'bob', 'lisa']

推薦《程式設計之美》

推薦 程式設計之美 我很早知道鄒欣計畫要寫這樣一本書,也能夠預計到這本書定會廣受歡迎,因為它符合當前大量求職人員的需求,畢竟於他們而言,誰不想知道微軟亞洲研究院在招人時候問些什麼問題呢。另一方面,把考察軟體技術人員專業知識和相應技能的各種手段加以歸納和整理,這本身也是對業界的貢獻,所以,我相信,一旦...

程式設計之美摘錄

第1章 遊戲之樂 遊戲中碰到的題目 1.1讓cpu佔用率曲線聽你的指揮 int main return 0 解法二 使用gettickcount 和sleep 解法三 能動態適應的解法 1.2中國象棋將帥問題 1.3一摞烙餅的排序 1.4買書問題 1.5快速找出故障機器 1.6飲料供貨 1.7光影切...

程式設計之美 2 2

1 階乘確實是乙個讓人頭疼的問題,其本身的實現很簡單,它的問題在於結果膨脹式的增長會造成n!的結果的溢位。2.2給出了幾種從數學角度出來的思路,可以避免上面的問題發生。首先要清楚的乙個問題就是質因數分解 給定任意乙個整數w,那麼w一定可以分解成w 2 x 3 y 5 m 這種形式,這個數學理論是解決...