Python新手在謀求一份Python程式設計工作前,必須熟知Python的基礎知識。程式設計網站DataFlair的技術團隊分享了一份2018年最常見Python面試題合集,既有基本的Python面試題,也有高階版試題來指導你準備面試,試題均附有答案。面試題內容包括編碼、資料結構、指令碼撰寫等話題。本文為上篇。
Q 1:Python有哪些特點和優點?
作為一門程式設計入門語言,Python主要有以下特點和優點:
- 可解釋
- 具有動態特性
- 物件導向
- 簡明簡單
- 開源
- 具有強大的社群支援
當然,實際上Python的優點遠不止如此,可以閱讀該文件,詳細瞭解:
Q 2:深拷貝和淺拷貝之間的區別是什麼?
答:深拷貝就是將一個物件拷貝到另一個物件中,這意味著如果你對一個物件的拷貝做出改變時,不會影響原物件。在Python中,我們使用函式deepcopy()執行深拷貝,匯入模組copy,如下所示:
>>> import copy
>>> b=copy.deepcopy(a)
複製程式碼
而淺拷貝則是將一個物件的引用拷貝到另一個物件上,所以如果我們在拷貝中改動,會影響到原物件。我們使用函式function()執行淺拷貝,使用如下所示:
>>> b=copy.copy(a)
複製程式碼
Q 3. 列表和元組之間的區別是?
答:二者的主要區別是列表是可變的,而元組是不可變的。舉個例子,如下所示:
>>> mylist=[1,3,3]
>>> mylist[1]=2
>>> mytuple=(1,3,3)
>>> mytuple[1]=2
Traceback (most recent call last):
File "<pyshell#97>", line 1, in <module>
mytuple[1]=2
複製程式碼
會出現以下報錯:
TypeError: ‘tuple’ object does not support item assignment
複製程式碼
關於列表和元組的更多內容,可以檢視這裡:
從Q4到Q20都是針對新手的Python面試基礎試題,不過有經驗的人也可以看看這些問題,複習一下基礎概念。
Q 4. 解釋一下Python中的三元運運算元
不像C++,我們在Python中沒有?:,但我們有這個:
[on true] if [expression] else [on false]
複製程式碼
如果表示式為True,就執行[on true]中的語句。否則,就執行[on false]中的語句。
下面是使用它的方法:
>>> a,b=2,3
>>> min=a if a<b else b
>>> min
複製程式碼
執行結果:
2
複製程式碼
>>> print("Hi") if a<b else print("Bye")
複製程式碼
執行結果:
Hi
複製程式碼
Q 5. 在Python中如何實現多執行緒?
一個執行緒就是一個輕量級程式,多執行緒能讓我們一次執行多個執行緒。我們都知道,Python是多執行緒語言,其內建有多執行緒工具包。
Python中的GIL(全域性直譯器鎖)確保一次執行單個執行緒。一個執行緒儲存GIL並在將其傳遞給下個執行緒之前執行一些操作,這會讓我們產生並行執行的錯覺。但實際上,只是執行緒在CPU上輪流執行。當然,所有的傳遞會增加程式執行的記憶體壓力。
Q 6. 解釋一下Python中的繼承
當一個類繼承自另一個類,它就被稱為一個子類/派生類,繼承自父類/基類/超類。它會繼承/獲取所有類成員(屬性和方法)。
繼承能讓我們重新使用程式碼,也能更容易的建立和維護應用。Python支援如下種類的繼承:
- 單繼承:一個類繼承自單個基類
- 多繼承:一個類繼承自多個基類
- 多級繼承:一個類繼承自單個基類,後者則繼承自另一個基類
- 分層繼承:多個類繼承自單個基類
- 混合繼承:兩種或多種型別繼承的混合 更多關於繼承的內容,參見:
Q 7. 什麼是Flask?
Flask是Python編寫的一款輕量級Web應用框架。其 WSGI 工具箱採用 Werkzeug ,模板引擎則使用 Jinja2。Flask使用 BSD 授權。其中兩個環境依賴是Werkzeug和jinja2,這意味著它不需要依賴外部庫。正因如此,我們將其稱為輕量級框架。
Flask會話使用簽名cookie讓使用者檢視和修改會話內容。它會記錄從一個請求到另一個請求的資訊。不過,要想修改會話,使用者必須有金鑰Flask.secret_key。
Q 8. 在Python中是如何管理記憶體的?
Python有一個私有堆空間來儲存所有的物件和資料結構。作為開發者,我們無法訪問它,是直譯器在管理它。但是有了核心API後,我們可以訪問一些工具。Python記憶體管理器控制記憶體分配。
另外,內建垃圾回收器會回收使用所有的未使用記憶體,所以使其適用於堆空間。
Q 9. 解釋Python中的help()和dir()函式
Help()函式是一個內建函式,用於檢視函式或模組用途的詳細說明:
>>> import copy
>>> help(copy.copy)
複製程式碼
執行結果為:
Help on function copy in module copy:
copy(x)
Shallow copy operation on arbitrary Python objects.
See the module’s __doc__ string for more info.
複製程式碼
Dir()函式也是Python內建函式,dir() 函式不帶引數時,返回當前範圍內的變數、方法和定義的型別列表;帶引數時,返回引數的屬性、方法列表。
以下例項展示了 dir 的使用方法:
>>> dir(copy.copy)
複製程式碼
執行結果為:
[‘__annotations__’, ‘__call__’, ‘__class__’, ‘__closure__’, ‘__code__’, ‘__defaults__’, ‘__delattr__’, ‘__dict__’, ‘__dir__’, ‘__doc__’, ‘__eq__’, ‘__format__’, ‘__ge__’, ‘__get__’, ‘__getattribute__’, ‘__globals__’, ‘__gt__’, ‘__hash__’, ‘__init__’, ‘__init_subclass__’, ‘__kwdefaults__’, ‘__le__’, ‘__lt__’, ‘__module__’, ‘__name__’, ‘__ne__’, ‘__new__’, ‘__qualname__’, ‘__reduce__’, ‘__reduce_ex__’, ‘__repr__’, ‘__setattr__’, ‘__sizeof__’, ‘__str__’, ‘__subclasshook__’]
複製程式碼
Q 10. 當退出Python時,是否釋放全部記憶體?
答案是No。迴圈引用其它物件或引用自全域性名稱空間的物件的模組,在Python退出時並非完全釋放。
另外,也不會釋放C庫保留的記憶體部分。
Q 11. 什麼是猴子補丁?
在執行期間動態修改一個類或模組。
>>> class A:
def func(self):
print("Hi")
>>> def monkey(self):
print "Hi, monkey"
>>> m.A.func = monkey
>>> a = m.A()
>>> a.func()
複製程式碼
執行結果為:
Hi, Monkey
複製程式碼
Q 12. Python中的字典是什麼?
字典是C++和Java等程式語言中所沒有的東西,它具有鍵值對。
>>> roots={25:5,16:4,9:3,4:2,1:1}
>>> type(roots)
<class 'dict'>
>>> roots[9]
複製程式碼
執行結果為:
3
複製程式碼
字典是不可變的,我們也能用一個推導式來建立它。
>>> roots={x**2:x for x in range(5,0,-1)}
>>> roots
複製程式碼
執行結果:
{25: 5, 16: 4, 9: 3, 4: 2, 1: 1}
複製程式碼
Q 13. 請解釋使用*args和**kwargs的含義
當我們不知道向函式傳遞多少引數時,比如我們向傳遞一個列表或元組,我們就使用*args。
>>> def func(*args):
for i in args:
print(i)
>>> func(3,2,1,4,7)
複製程式碼
執行結果為:
3
2
1
4
7
複製程式碼
在我們不知道該傳遞多少關鍵字引數時,使用**kwargs來收集關鍵字引數。
>>> def func(**kwargs):
for i in kwargs:
print(i,kwargs[i])
>>> func(a=1,b=2,c=7)
複製程式碼
執行結果為:
a.1
b.2
c.7
複製程式碼
Q 14. 請寫一個Python邏輯,計算一個檔案中的大寫字母數量
>>> import os
>>> os.chdir('C:\\Users\\lifei\\Desktop')
>>> with open('Today.txt') as today:
count=0
for i in today.read():
if i.isupper():
count+=1
print(count)
複製程式碼
執行結果:
26
複製程式碼
Q 15. 什麼是負索引?
我們先建立這樣一個列表:
>>> mylist=[0,1,2,3,4,5,6,7,8]
複製程式碼
負索引和正索引不同,它是從右邊開始檢索。
>>> mylist[-3]
複製程式碼
執行結果:
6
複製程式碼
它也能用於列表中的切片:
>>> mylist[-6:-1]
複製程式碼
結果:
[3, 4, 5, 6, 7]
複製程式碼
Q 16. 如何以就地操作方式打亂一個列表的元素?
為了達到這個目的,我們從random模組中匯入shuffle()函式。
>>> from random import shuffle
>>> shuffle(mylist)
>>> mylist
複製程式碼
執行結果:
[3, 4, 8, 0, 5, 7, 6, 2, 1]
複製程式碼
Q 17. 解釋Python中的join()和split()函式
Join()能讓我們將指定字元新增至字串中。
>>> ','.join('12345')
複製程式碼
執行結果:
‘1,2,3,4,5’
複製程式碼
Split()能讓我們用指定字元分割字串。
>>> '1,2,3,4,5'.split(',')
複製程式碼
執行結果:
[‘1’, ‘2’, ‘3’, ‘4’, ‘5’]
複製程式碼
Q 18. Python區分大小寫嗎?
如果能區分像myname和Myname這樣的識別符號,那麼它就是區分大小寫的。也就是說它很在乎大寫和小寫。我們可以用Python試一試:
>>> myname='Ayushi'
>>> Myname
Traceback (most recent call last):
File "<pyshell#3>", line 1, in <module>
複製程式碼
執行結果:
Myname
NameError: name ‘Myname’ is not defined
複製程式碼
可以看到,這裡出現了NameError,所以Python是區分大小寫的。
Q 19. Python中的識別符號長度能有多長?
在Python中,識別符號可以是任意長度。此外,我們在命名識別符號時還必須遵守以下規則:
-
只能以下劃線或者 A-Z/a-z 中的字母開頭
-
其餘部分可以使用 A-Z/a-z/0-9
-
區分大小寫
-
關鍵字不能作為識別符號,Python中共有如下關鍵字:
Q 20. 怎麼移除一個字串中的前導空格?
字串中的前導空格就是出現在字串中第一個非空格字元前的空格。我們使用方法Istrip()可以將它從字串中移除。
>>> ' Ayushi '.lstrip()
複製程式碼
結果:
‘Ayushi ’
複製程式碼
可以看到,該字串既有前導字元,也有字尾字元,呼叫Istrip()去除了前導空格。如果我們想去除字尾空格,就用rstrip()方法。
>>> ' Ayushi '.rstrip()
複製程式碼
結果:
‘ Ayushi’
複製程式碼
從Q 21到Q 35是為有Python經驗者準備的進階版Python面試題。
Q 21. 怎樣將字串轉換為小寫?
我們使用lower()方法。
>>> 'AyuShi'.lower()
複製程式碼
結果:
‘ayushi’
複製程式碼
使用upper()方法可以將其轉換為大寫。
>>> 'AyuShi'.upper()
複製程式碼
結果:
‘AYUSHI’
複製程式碼
另外,使用isupper()和islower()方法檢查字元春是否全為大寫或小寫。
>>> 'AyuShi'.isupper()
False
>>> 'AYUSHI'.isupper()
True
>>> 'ayushi'.islower()
True
>>> '@yu$hi'.islower()
True
>>> '@YU$HI'.isupper()
True
複製程式碼
那麼,像@和$這樣的字元既滿足大寫也滿足小寫。
Istitle()能告訴我們一個字串是否為標題格式。
>>> 'The Corpse Bride'.istitle()
True
複製程式碼
Q 22. Python中的pass語句是什麼?
在用Python寫程式碼時,有時可能還沒想好函式怎麼寫,只寫了函式宣告,但為了保證語法正確,必須輸入一些東西,在這種情況下,我們會使用pass語句。
>>> def func(*args):
pass
>>>
複製程式碼
同樣,break語句能讓我們跳出迴圈。
>>> for i in range(7):
if i==3: break
print(i)
複製程式碼
結果:
0
1
2
複製程式碼
最後,continue語句能讓我們跳到下個迴圈。
>>> for i in range(7):
if i==3: continue
print(i)
複製程式碼
結果:
0
1
2
4
5
6
複製程式碼
Q 23. Python中的閉包是什麼?
當一個巢狀函式在其外部區域引用了一個值時,該巢狀函式就是一個閉包。其意義就是會記錄這個值。
>>> def A(x):
def B():
print(x)
return B
>>> A(7)()
複製程式碼
結果:
7
複製程式碼
更多關於閉包的知識,請參看這裡:
Q 24. 解釋一下Python中的//,%和 ** 運算子
//運算子執行地板除法(向下取整除),它會返回整除結果的整數部分。
>>> 7//2
3
複製程式碼
這裡整除後會返回3.5。
同樣地,執行取冪運算。ab會返回a的b次方。
>>> 2**10
1024
複製程式碼
最後,%執行取模運算,返回除法的餘數。
>>> 13%7
6
>>> 3.5%1.5
0.5
複製程式碼
Q 25. 在Python中有多少種運算子?解釋一下算數運算子。
在Python中,我們有7種運算子:算術運算子、關係運算子、賦值運算子、邏輯運算子、位運算子、成員運算子、身份運算子。
我們有7個算術運算子,能讓我們對數值進行算術運算:
1.加號(+),將兩個值相加
>>> 7+8
15
複製程式碼
2.減號(-),將第一個值減去第二個值
>>> 7-8
-1
複製程式碼
3.乘號(*),將兩個值相乘
>>> 7*8
56
複製程式碼
4.除號(/),用第二個值除以第一個值
>>> 7/8
0.875
>>> 1/1
1.0
複製程式碼
5.向下取整除、取模和取冪運算,參見上個問題。
Q 26. 解釋一下Python中的關係運算子
關係運算子用於比較兩個值。
1.小於號(<),如果左邊的值較小,則返回True。
>>> 'hi'<'Hi'
False
複製程式碼
2.大於號(>),如果左邊的值較大,則返回True。
>>> 1.1+2.2>3.3
True
複製程式碼
3.小於等於號(<=),如果左邊的值小於或等於右邊的值,則返回Ture。
>>> 3.0<=3
True
複製程式碼
4.大於等於號(>=),如果左邊的值大於或等於右邊的值,則返回True。
>>> True>=False
True
複製程式碼
- 等於號(==),如果符號兩邊的值相等,則返回True。
>>> {1,3,2,2}=={1,2,3}
True
複製程式碼
- 不等於號(!=),如果符號兩邊的值不相等,則返回True。
>>> True!=0.1
True
>>> False!=0.1
True
複製程式碼
Q 27. 解釋一下Python中的賦值運算子
這在Python面試中是個重要的面試問題。
我們將所有的算術運算子和賦值符號放在一起展示:
>>> a=7
>>> a+=1
>>> a
8
>>> a-=1
>>> a
7
>>> a*=2
>>> a
14
>>> a/=2
>>> a
7.0
>>> a**=2
>>> a
49
>>> a//=3
>>> a
16.0
>>> a%=4
>>> a
0.0
複製程式碼
Q 28. 解釋一下Python中的邏輯運算子
Python中有3個邏輯運算子:and,or,not。
>>> False and True
False
>>> 7<7 or True
True
>>> not 2==2
False
複製程式碼
Q 29. 解釋一下Python中的成員運算子
通過成員運算子‘in’和‘not in’,我們可以確認一個值是否是另一個值的成員。
>>> 'me' in 'disappointment'
True
>>> 'us' not in 'disappointment'
True
複製程式碼
Q 30. 解釋一下Python中的身份運算子
這也是一個在Python面試中常問的問題。
通過身份運算子‘is’和‘is not’,我們可以確認兩個值是否相同。
>>> 10 is '10'
False
>>> True is not False
True
複製程式碼
Q 31. 講講Python中的位運算子
該運算子按二進位制位對值進行操作。
- 與(&),按位與運算子:參與運算的兩個值,如果兩個相應位都為1,則該位的結果為1,否則為0
>>> 0b110 & 0b010
2
複製程式碼
2.或(|),按位或運算子:只要對應的二個二進位有一個為1時,結果位就為1。
>>> 3|2
3
複製程式碼
3.異或(^),按位異或運算子:當兩對應的二進位相異時,結果為1
>>> 3^2
1
複製程式碼
4.取反(~),按位取反運算子:對資料的每個二進位制位取反,即把1變為0,把0變為1
>>> ~2
-3
複製程式碼
5.左位移(<<),運算數的各二進位全部左移若干位,由 << 右邊的數字指定了移動的位數,高位丟棄,低位補0
>>> 1<<2
4
複製程式碼
6.右位移(>>),把">>"左邊的運算數的各二進位全部右移若干位,>> 右邊的數字指定了移動的位數
>>> 4>>2
1
複製程式碼
更多關於運算子的知識,參考這裡:
Q 32. 在Python中如何使用多進位制數字?
我們在Python中,除十進位制外還可以使用二進位制、八進位制和十六進位制。
- 二進位制數字由0和1組成,我們使用 0b 或 0B 字首表示二進位制數。
>>> int(0b1010)
10
複製程式碼
2.使用bin()函式將一個數字轉換為它的二進位制形式。
>>> bin(0xf)
‘0b1111’
複製程式碼
3.八進位制數由數字 0-7 組成,用字首 0o 或 0O 表示 8 進位制數。
>>> oct(8)
‘0o10’
複製程式碼
4.十六進數由數字 0-15 組成,用字首 0x 或者 0X 表示 16 進位制數。
>>> hex(16)
‘0x10’
>>> hex(15)
‘0xf’
複製程式碼
Q 33. 怎樣獲取字典中所有鍵的列表?
使用 keys() 獲取字典中的所有鍵
>>> mydict={'a':1,'b':2,'c':3,'e':5}
>>> mydict.keys()
dict_keys(['a', 'b', 'c', 'e'])
複製程式碼
Q 34. 為何不建議以下劃線作為識別符號的開頭
因為Python並沒有私有變數的概念,所以約定速成以下劃線為開頭來宣告一個變數為私有。所以如果你不想讓變數私有,就不要使用下劃線開頭。
Q 35. 怎樣宣告多個變數並賦值?
一共有兩種方式:
>>> a,b,c=3,4,5 #This assigns 3, 4, and 5 to a, b, and c respectively
>>> a=b=c=3 #This assigns 3 to a, b, and c
複製程式碼
Q 36. 元組的解封裝是什麼?
首先我們來看解封裝:
>>> mytuple=3,4,5
>>> mytuple
(3, 4, 5)
複製程式碼
這將 3,4,5 封裝到元組 mytuple 中。
現在我們將這些值解封裝到變數 x,y,z 中:
>>> x,y,z=mytuple
>>> x+y+z
複製程式碼
得到結果12.
結語
以上就是Python面試中一些常見的問題及其答案,我們在下篇會接著分享更多問題,歡迎關注。