Python是個非常受歡迎的編程語言,隨著近些年機(jī)器學(xué)習(xí)、云計算等技術(shù)的發(fā)展,Python的職位需求越來越高。我收集了110道Python面試官經(jīng)常問的問題,供大家參考學(xué)習(xí)。篇幅問題,分為2次推送,下周會給大家分享面試題下篇55道~

1、一行代碼實現(xiàn)1--100之和

利用sum()函數(shù)求和。

2、如何在一個函數(shù)內(nèi)部修改全局變量

利用global 修改全局變量。

3、列出5個python標(biāo)準(zhǔn)庫

os:提供了不少與操作系統(tǒng)相關(guān)聯(lián)的函數(shù)

sys: 通常用于命令行參數(shù)

re: 正則匹配

math: 數(shù)學(xué)運算

datetime:處理日期時間

4、字典如何刪除鍵和合并兩個字典

del和update方法。

5、談下python的GIL

GIL 是python的全局解釋器鎖,同一進(jìn)程中假如有多個線程運行,一個線程在運行python程序的時候會霸占python解釋器(加了一把鎖即GIL),使該進(jìn)程內(nèi)的其他線程無法運行,等該線程運行完后其他線程才能運行。如果線程運行過程中遇到耗時操作,則解釋器鎖解開,使其他線程運行。所以在多線程中,線程的運行仍是有先后順序的,并不是同時進(jìn)行。

多進(jìn)程中因為每個進(jìn)程都能被系統(tǒng)分配資源,相當(dāng)于每個進(jìn)程有了一個python解釋器,所以多進(jìn)程可以實現(xiàn)多個進(jìn)程的同時運行,缺點是進(jìn)程系統(tǒng)資源開銷大。

6、python實現(xiàn)列表去重的方法

先通過集合去重,在轉(zhuǎn)列表。

7、fun(*args,* kwargs)中的 args,**kwargs什么意思?

8、python2和python3的range(100)的區(qū)別

python2返回列表,python3返回迭代器,節(jié)約內(nèi)存。

9、一句話解釋什么樣的語言能夠用裝飾器?

函數(shù)可以作為參數(shù)傳遞的語言,可以使用裝飾器。

10、python內(nèi)建數(shù)據(jù)類型有哪些

整型--int

布爾型--bool

字符串--str

列表--list

元組--tuple

字典--dict

11、簡述面向?qū)ο笾? new init 區(qū)別

init 是初始化方法,創(chuàng)建對象后,就立刻被默認(rèn)調(diào)用了,可接收參數(shù),如圖

(1) new 至少要有一個參數(shù)cls,代表當(dāng)前類,此參數(shù)在實例化時由Python解釋器自動識別。

(2) new 必須要有返回值,返回實例化出來的實例,這點在自己實現(xiàn) new 時要特別注意,可以return父類(通過super(當(dāng)前類名, cls)) new 出來的實例,或者直接是object的 new 出來的實例。

(3) init 有一個參數(shù)self,就是這個 new 返回的實例, init new 的基礎(chǔ)上可以完成一些其它初始化的動作, init 不需要返回值。

(4)如果 new 創(chuàng)建的是當(dāng)前類的實例,會自動調(diào)用 init 函數(shù),通過return語句里面調(diào)用的 new 函數(shù)的第一個參數(shù)是cls來保證是當(dāng)前類實例,如果是其他類的類名,;那么實際創(chuàng)建返回的就是其他類的實例,其實就不會調(diào)用當(dāng)前類的 init 函數(shù),也不會調(diào)用其他類的 init 函數(shù)。

12、簡述with方法打開處理文件幫我我們做了什么?

打開文件在進(jìn)行讀寫的時候可能會出現(xiàn)一些異常狀況,如果按照常規(guī)的f.open。

寫法,我們需要try,except,finally,做異常判斷,并且文件最終不管遇到什么情況,都要執(zhí)行finally f.close()關(guān)閉文件,with方法幫我們實現(xiàn)了finally中f.close。

(當(dāng)然還有其他自定義功能,有興趣可以研究with方法源碼)

13、列表[1,2,3,4,5],請使用map()函數(shù)輸出[1,4,9,16,25],并使用列表推導(dǎo)式提取出大于10的數(shù),最終輸出[16,25]

map()函數(shù)第一個參數(shù)是fun,第二個參數(shù)是一般是list,第三個參數(shù)可以寫list,也可以不寫,根據(jù)需求。

14、python中生成隨機(jī)整數(shù)、隨機(jī)小數(shù)、0--1之間小數(shù)方法

隨機(jī)整數(shù):random.randint(a,b),生成區(qū)間內(nèi)的整數(shù)。

隨機(jī)小數(shù):習(xí)慣用numpy庫,利用np.random.randn(5)生成5個隨機(jī)小數(shù)。

0-1隨機(jī)小數(shù):random.random(),括號中不傳參。

15、避免轉(zhuǎn)義給字符串加哪個字母表示原始字符串?

r , 表示需要原始字符串,不轉(zhuǎn)義特殊字符。

16、

中國
,用正則匹配出標(biāo)簽里面的內(nèi)容(“中國”),其中class的類名是不確定的

17、python中斷言方法舉例

assert()方法,斷言成功,則程序繼續(xù)執(zhí)行,斷言失敗,則程序報錯。

18、數(shù)據(jù)表student有id,name,score,city字段,其中name中的名字可有重復(fù),需要消除重復(fù)行,請寫sql語句

select distinct name from student

19、10個Linux常用命令

ls pwd cd touch rm mkdir tree cp mv cat more grep echo

20、python2和python3區(qū)別?列舉5個

(1)Python3 使用 print 必須要以小括號包裹打印內(nèi)容,比如 print('hi');

Python2 既可以使用帶小括號的方式,也可以使用一個空格來分隔打印內(nèi)容,比如 print 'hi';

(2)python2 range(1,10)返回列表,python3中返回迭代器,節(jié)約內(nèi)存;

(3)python2中使用ascii編碼,python中使用utf-8編碼;

(4)python2中unicode表示字符串序列,str表示字節(jié)序列;python3中str表示字符串序列,byte表示字節(jié)序列;

(5)python2中為正常顯示中文,引入coding聲明,python3中不需要;

(6)python2中是raw_input()函數(shù),python3中是input()函數(shù)。

21、列出python中可變數(shù)據(jù)類型和不可變數(shù)據(jù)類型,并簡述原理

不可變數(shù)據(jù)類型:數(shù)值型、字符串型string和元組tuple;

不允許變量的值發(fā)生變化,如果改變了變量的值,相當(dāng)于是新建了一個對象,而對于相同的值的對象,在內(nèi)存中則只有一個對象(一個地址),如下圖用id()方法可以打印對象的id。

可變數(shù)據(jù)類型:列表list和字典dict;

允許變量的值發(fā)生變化,即如果對變量進(jìn)行append、+=等這種操作后,只是改變了變量的值,而不會新建一個對象,變量引用的對象的地址也不會變化,不過對于相同的值的不同對象,在內(nèi)存中則會存在不同的對象,即每個對象都有自己的地址,相當(dāng)于內(nèi)存中對于同值的對象保存了多份,這里不存在引用計數(shù),是實實在在的對象。

22、s = "ajldjlajfdljfddd",去重并從小到大排序輸出"adfjl"

set去重,去重轉(zhuǎn)成list,利用sort方法排序,reeverse=False是從小到大排;

list是不 變數(shù)據(jù)類型,s.sort時候沒有返回值,所以注釋的代碼寫法不正確。

23、用lambda函數(shù)實現(xiàn)兩個數(shù)相乘

24、字典根據(jù)鍵從小到大排序

dict={"name":"zs","age":18,"city":"深圳","tel":"1362626627"}

25、利用collections庫的Counter方法統(tǒng)計字符串每個單詞出現(xiàn)的次數(shù)"kjalfj;ldsjafl;hdsllfdhg;lahfbl;hl;ahlf;h"

26、字符串a(chǎn) = "not 404 found 張三 99 深圳",每個詞中間是空格,用正則過濾掉英文和數(shù)字,最終輸出"張三 深圳"

順便貼上匹配小數(shù)的代碼,雖然能匹配,但是健壯性有待進(jìn)一步確認(rèn)。

27、filter方法求出列表所有奇數(shù)并構(gòu)造新列表,a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

filter() 函數(shù)用于過濾序列,過濾掉不符合條件的元素,返回由符合條件元素組成的新列表。該接收兩個參數(shù),第一個為函數(shù),第二個為序列,序列的每個元素作為參數(shù)傳遞給函數(shù)進(jìn)行判,然后返回 True 或 False,最后將返回 True 的元素放到新列表。

28、列表推導(dǎo)式求列表所有奇數(shù)并構(gòu)造新列表,a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

29、正則re.complie作用

re.compile是將正則表達(dá)式編譯成一個對象,加快速度,并重復(fù)使用。

30、a=(1,)b=(1),c=("1") 分別是什么類型的數(shù)據(jù)?

31、兩個列表[1,5,7,9]和[2,2,6,8]合并為[1,2,2,3,6,7,8,9]

extend可以將另一個集合中的元素逐一添加到列表中,區(qū)別于append整體添加。

32、用python刪除文件和用linux命令刪除文件方法

python:os.remove(文件名)

linux: rm 文件名

33、log日志中,我們需要用時間戳記錄error,warning等的發(fā)生時間,請用datetime模塊打印當(dāng)前時間戳 “2018-04-01 11:38:54”

順便把星期的代碼也貼上了。

34、數(shù)據(jù)庫優(yōu)化查詢方法

外鍵、索引、聯(lián)合查詢、選擇特定字段等等。

35、請列出你會的任意一種統(tǒng)計圖(條形圖、折線圖等)繪制的開源庫,第三方也行

pychart、matplotlib。

36、寫一段自定義異常代碼

自定義異常用raise拋出異常。

37、正則表達(dá)式匹配中,(. )和(. ?)匹配區(qū)別?

(.*)是貪婪匹配,會把滿足正則的盡可能多的往后匹配,

(.*?)是非貪婪匹配,會把滿足正則的盡可能少匹配。

38、簡述Django的orm

ORM,全拼Object-Relation Mapping,意為對象-關(guān)系映射。

實現(xiàn)了數(shù)據(jù)模型與數(shù)據(jù)庫的解耦,通過簡單的配置就可以輕松更換數(shù)據(jù)庫,而不需要修改代碼只需要面向?qū)ο缶幊蹋琽rm操作本質(zhì)上會根據(jù)對接的數(shù)據(jù)庫引擎,翻譯成對應(yīng)的sql語句,所有使用Django開發(fā)的項目無需關(guān)心程序底層使用的是MySQL、Oracle、sqlite....,如果數(shù)據(jù)庫遷移,只需要更換Django的數(shù)據(jù)庫引擎即可。

39、[[1,2],[3,4],[5,6]]一行代碼展開該列表,得出[1,2,3,4,5,6]

列表推導(dǎo)式的騷操作

運行過程:for i in a ,每個i是【1,2】,【3,4】,【5,6】,for j in i,每個j就是1,2,3,4,5,6,合并后就是結(jié)果。

還有更騷的方法,將列表轉(zhuǎn)成numpy矩陣,通過numpy的flatten()方法,代碼永遠(yuǎn)是只有更騷,沒有最騷~

40、x="abc",y="def",z=["d","e","f"],分別求出x.join(y)和x.join(z)返回的結(jié)果

join()括號里面的是可迭代對象,x插入可迭代對象中間,形成字符串,結(jié)果一致,有沒有突然感覺字符串的常見操作都不會玩了~

順便建議大家學(xué)下os.path.join()方法,拼接路徑經(jīng)常用到,也用到了join,和字符串操作中的join有什么區(qū)別,該問題大家可以查閱相關(guān)文檔,后期會有答案。

41、舉例說明異常模塊中try except else finally的相關(guān)意義

try..except..else沒有捕獲到異常,執(zhí)行else語句;

try..except..finally不管是否捕獲到異常,都執(zhí)行finally語句。

42、python中交換兩個數(shù)值

43、舉例說明zip()函數(shù)用法

zip()函數(shù)在運算時,會以一個或多個序列(可迭代對象)做為參數(shù),返回一個元組的列表。同時將這些序列中并排的元素配對。

zip()參數(shù)可以接受任何類型的序列,同時也可以有兩個以上的參數(shù);當(dāng)傳入?yún)?shù)的長度不同時,zip能自動以最短序列長度為準(zhǔn)進(jìn)行截取,獲得元組。

44、a="張明 98分",用re.sub,將98替換為100

45、寫5條常用sql語句

show databases;

show tables;

desc 表名;

select * from 表名;

delete from 表名 where id=5;

update students set gender=0,hometown="北京" where id=5

46、a="hello"和b="你好"編碼成bytes類型

47、[1,2,3]+[4,5,6]的結(jié)果是多少?

兩個列表相加,等價于extend。

48、提高python運行效率的方法

(1)使用生成器,因為可以節(jié)約大量內(nèi)存

(2)循環(huán)代碼優(yōu)化,避免過多重復(fù)代碼的執(zhí)行

(3)核心模塊用Cython PyPy等,提高效率

(4)多進(jìn)程、多線程、協(xié)程

(5)多個if elif條件判斷,可以把最有可能先發(fā)生的條件放到前面寫,這樣可以減少程序判斷的次數(shù),提高效率

49、簡述mysql和redis區(qū)別

redis:內(nèi)存型非關(guān)系數(shù)據(jù)庫,數(shù)據(jù)保存在內(nèi)存中,速度快。

mysql:關(guān)系型數(shù)據(jù)庫,數(shù)據(jù)保存在磁盤中,檢索的話,會有一定的Io操作,訪問速度相對慢。

50、遇到bug如何處理

(1)細(xì)節(jié)上的錯誤,通過print()打印,能執(zhí)行到print()說明一般上面的代碼沒有問題,分段檢測程序是否有問題,如果是js的話可以alert或console.log

(2)如果涉及一些第三方框架,會去查官方文檔或者一些技術(shù)博客。

(3)對于bug的管理與歸類總結(jié),一般測試將測試出的bug用teambin等bug管理工具進(jìn)行記錄,然后我們會一條一條進(jìn)行修改,修改的過程也是理解業(yè)務(wù)邏輯和提高自己編程邏輯縝密性的方法,我也都會收藏做一些筆記記錄。

(4)導(dǎo)包問題、城市定位多音字造成的顯示錯誤問題。

51、正則匹配,匹配日期2018-03-20

url='https://sycm.taobao.com/bda/tradinganaly/overview/get_summary.json?dateRange=2018-03-20%7C2018-03-20&dateType=recent1&device=1&token=ff25b109b&_=1521595613462'

仍有同學(xué)問正則,其實匹配并不難,提取一段特征語句,用(.*?)匹配即可。

52、list=[2,3,5,4,9,6],從小到大排序,不許用sort,輸出[2,3,4,5,6,9]

利用min()方法求出最小值,原列表刪除最小值,新列表加入最小值,遞歸調(diào)用獲取最小值的函數(shù),反復(fù)操作。

53、寫一個單列模式

因為創(chuàng)建對象時 new 方法執(zhí)行,并且必須return 返回實例化出來的對象所cls.__instance是否存在,不存在的話就創(chuàng)建對象,存在的話就返回該對象,來保證只有一個實例對象存在(單列),打印ID,值一樣,說明對象同一個。

54、保留兩位小數(shù)

題目本身只有a="%.03f"%1.3335,讓計算a的結(jié)果,為了擴(kuò)充保留小數(shù)的思路,提供round方法(數(shù)值,保留位數(shù))。

55、求三個方法打印結(jié)果

fn("one",1)直接將鍵值對傳給字典;

fn("two",2)因為字典在內(nèi)存中是可變數(shù)據(jù)類型,所以指向同一個地址,傳了新的額參數(shù)后,會相當(dāng)于給字典增加鍵值對;

fn("three",3,{})因為傳了一個新字典,所以不再是原先默認(rèn)參數(shù)的字典。

?