自學Python6個月,你能找到工作嗎?快用這份面試題測試一下吧

自學Python已有一段時間了,就想着找份面試題來檢驗一下自己的學習情況,今天就和大家分享一份自己從網上找到的貨真價實的Python面試題,每道題目看似簡單,但如果基礎知識不牢固,很容易回答不全面。

1. python 常用數據結構有哪些?請簡要介紹一下。

答:Python中常見的數據結構可以統稱爲容器(container)。序列(如列表和元組)、映射(如字典)以及集合(set)是三類主要的容器。所以,Python常用數據結構有:列表、字典、元組、集合

關於這個問題,一般也會順帶問:Python中哪些數據類型是可變的,哪些是不可變的?

答:可變/不可變是針對該對象所指向的內存中的值是否可變來判斷的。如可變類型的數據類型有:列表、字典、集合;不可變類型的數據類型有:字符串、元組、數字

2. 簡要描述 Python 中單引號、雙引號、三引號的區別。

答:首先,單引號和雙引號在使用時基本上沒有什麼區別;

唯一需要注意的是:

當字符串中有單引號時,最好在外面使用雙引號;

當有雙引號時,最好在外面使用單引號;

三引號一般不常用,除了用來做註釋外,還可以用來打印多行字符串。特殊用途,是可以打印多行字符串。

3. 如何在一個 function 裏面設置一個全局的變量?

答:全局變量是指定義在函數外部的變量。全局變量的作用域爲全局。

局部變量是指定義在函數內部的變量。局部變量的作用域爲函數內,除了函數就無效了。

例如:

num=100deffunc():globalnumnum=200num+=100print(num)func()print(num)300300

總結:如果要在函數中給全局變量賦值,需要用global關鍵字聲明。

4. Python 裏面如何拷貝一個對象?(賦值、淺拷貝、深拷貝的區別)

答:賦值是將一個對象的地址賦值給一個變量,讓變量指向該地址(舊瓶裝舊酒

淺拷貝就是對引用的拷貝

深拷貝是對對象的資源的拷貝

舉例說明:

(1)

a = ['hello',[1,2,3]]

b = a[:]

print([id(x) for x in a])

print([id(x) for x in b])

a[0] = 'world'

a[1].append(4)

print(a)

print(b)

[34305224, 33841800]

[34305224, 33841800]

['world', [1, 2, 3, 4]]

['hello', [1, 2, 3, 4]]

淺拷貝是在另一塊地址中創建一個新的變量或容器,但是容器內的元素的地址均是源對象的元素的地址的拷貝。也就是說新的容器中指向了舊的元素(新瓶裝舊酒)。

(2)

from copy import deepcopy

a = ['hello',[1,2,3]]

b = deepcopy(a)

print([id(x) for x in a])

print([id(x) for x in b])

a[0] = 'world'

a[1].append(4)

print(a)

print(b)

[30766280, 30785352]

[30766280, 31727688]

['world', [1, 2, 3, 4]]

['hello', [1, 2, 3]]

深拷貝是在另一塊地址中創建一個新的變量或容器,同時容器內的元素的地址也是新開闢的,僅僅是值相同而已,是完全的副本。也就是說(新瓶裝新酒)。

總 結

(1)當對象爲不可變類型時,不論是賦值,淺拷貝還是深拷貝,那麼改變其中一個值時,另一個都是不會跟着變化的。

(2)當對象爲可變對象時,如果是賦值和淺拷貝,那麼改變其中任意一個值,那麼另一個會跟着發生變化的;如果是深拷貝,是不會跟着發生改變的。

5. 如果 custname 字符串的內容爲 utf-8 的字符,如何將 custname 的內容轉爲 gb18030 的字符串?

答:先將custname編碼格式轉換爲unicode,再轉換爲gb18030。即custname.decode(‘utf-8’).encode(‘gb18030’)。

6. 請寫出一段 Python 代碼實現刪除一個 list 裏面的重複元素。

答:方法(一)利用集合set的特性,元素是非重複的

a = [1,2,3,4,5,2,3]

def fun1(a):

    a = list(set(a))

    print(a)

fun1(a)

[1, 2, 3, 4, 5]

方法(二)利用字典的fromkeys來自動過濾重複值

a = [1,2,3,4,5,2,3]

def fun1(a):

    b = {}

    b = b.fromkeys(a)

    c = list(b.keys())

    print(c)

c = fun1(a)

7. 這兩個參數是什麼意思:*args,**kwargs?

答:首先,*args和**kwargs並不是必須這樣寫,只有前面的*和**纔是必須的,你可以寫成*var和**vars。

其次,*args和**kwargs主要用於函數定義,你可以將不定量的參數傳遞給一個函數。

其中,*args是用來發送一個非鍵值對的可變數量的參數列表給一個函數;

**kwargs則允許將不定長度的鍵值對,作爲參數傳遞給一個函數,如果你想要在一個函數裏處理帶名字的參數,你應該使用**kwargs。

8. 統計如下 list 單詞及其出現次數。

a=['apple', 'banana', 'apple', 'tomato', 'orange', 'apple', 'banana', 'watermeton']

答:我能想到的最簡單的方法就是用collection庫

from collections import Counter

a = ['apple', 'banana', 'apple', 'tomato', 'orange', 'apple', 'banana', 'watermeton']

b = Counter(a)

print(b)

Counter({'apple': 3, 'banana': 2, 'tomato': 1, 'orange': 1, 'watermeton': 1})

9. 給列表中的字典排序:假設有如下 list 對象

alist=[{"name":"a", "age":20}, {"name":"b", "age":30}, {"name":"c", "age":25}]

將 alist 中的元素按照 age 從大到小排序。

答:利用list的內置函數sort來進行排序

alist=[{"name":"a", "age":20}, {"name":"b", "age":30}, {"name":"c", "age":25}]

alist.sort(key=lambda x:x['age'])

print(alist)

[{'name': 'a', 'age': 20}, {'name': 'c', 'age': 25}, {'name': 'b', 'age': 30}]

10. 寫出下列代碼的運行結果

a = 1

def fun(a):

  a = 2

fun(a)

print(a)

a = []

def fun(a):

  a.append(1)

fun(a)

print(a)

class Person:

    name = 'Lily'

p1 = Person()

p2 = Person()

p1.name = 'Bob'

print(p1.name)

print(p2.name)

print(Person.name)

答:第一段代碼的運行結果爲:1

第二段代碼的運行結果爲:[1]

第三段代碼的運行結果爲:

Bob

Lily

Lily

11. 假設有如下兩個 list:a = ['a', 'b', 'c', 'd', 'e'],b = [1, 2, 3, 4, 5],將 a 中的元素作爲 key,b 中元素作爲 value,將 a,b 合併爲字典。

答:

a = ['a','b','c','d','e']

b = [1,2,3,4,5]

c = dict(zip(a,b))

print(c)

總結

通過做這份真實的面試題,我發現自己對一些知識掌握的比較模糊,基礎知識還有待進一步的,導致對一些問題回答的還不夠全面。

最後,我覺得這也是一種學Python的好方法呀,可以不斷檢驗自己的學習情況,督促自己不斷進步。

小夥伴們,你們做對了幾道呀?歡迎留言交流Python學習。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章