第1題:字串的拼接–如何高效的拼接兩個字串?
字串拼接的幾種方法
- 加號
- 逗號
- 直接連線
- 格式化
- join
- 多行字串拼接()
加號
print('Python' + 'Plus')
複製程式碼
逗號
print("Hello", "Python")
複製程式碼
直接連線
print("Hello" "Python")
複製程式碼
格式化
print('%s %s'%('Python', 'PLUS'))
複製程式碼
join
str_list = ['Python', 'Plus']
a = ''
print(a.join(str_list))
複製程式碼
多行字串拼接()
sql = ('select *'
'from users'
'where id=666')
print(sql)
複製程式碼
一般情況,大家比較喜歡用“+”拼接字串,但是這個方法並不是高效的,
因為如果需要拼接的字串有很多(n個)的情況下,
使用”+”的話,python直譯器會申請n-1次記憶體空間,
然後進行拷貝,因為字串在python中是不可變的,
所以當進行拼接的時候,會需要申請一個新的記憶體空間。
所以,正確答案是,使用.join(list),因為它只使用了一次記憶體空間
複製程式碼
第2題: list = ['a','a','a',1,2,3,4,5,'A','B','C']提取出”12345”?
這個考點考了python的解壓賦值的知識點,即 a,b,c,*middle,d,e,f = list, *middle = [1,2,3,4,5]。
注意,解壓賦值提取出來的是列表
list = ['a','a','a',1,2,3,4,5,'A','B','C']
a,b,c,*middle,d,e,f = list
print(middle)
print(type(middle))
複製程式碼
第3題: 什麼是pickling和unpickling?
為了讓使用者在平常的程式設計和測試時儲存複雜的資料型別,python提供了標準模組,稱為pickle
。
這個模組可以將幾乎任何的python物件(甚至是python的程式碼),轉換為字串表示,這個過程稱為pickling
。
從儲存的字串中檢索原始Python物件的過程稱為unpickling
。
第4題: 說一說Python自省?
在python中,檢查某些事物以確定它是什麼、它知道什麼以及它能做什麼。
自省向程式設計師提供了極大的靈活性和控制力。
說的更簡單直白一點:==自省就是物件導向的語言所寫的程式在執行時,能夠知道物件的型別。簡單一句就是,執行時能夠獲知物件的型別。==
例如python, buby, object-C, c++都有自省的能力,這裡面的c++的自省的能力最弱,只能夠知道是什麼型別,而像python可以知道是什麼型別,還有什麼屬性。
Python中比較常見的自省(introspection)機制(函式用法)有: dir()
,type()
, hasattr()
, isinstance()
,通過這些函式,我們能夠在程式執行時得知物件的型別,判斷物件是否存在某個屬性,訪問物件的屬性。
- dir() 函式是 Python 自省機制中最著名的部分了。它返回傳遞給它的任何物件的屬性名稱經過排序的列表。如果不指定物件,則 dir() 返回當前作用域中的名稱。
- type() 函式有助於我們確定物件是字串還是整數,或是其它型別的物件。
- 物件擁有屬性,並且 dir() 函式會返回這些屬性的列表。但是,有時我們只想測試一個或多個屬性是否存在。如果物件具有我們正在考慮的屬性,那麼通常希望只檢索該屬性。這個任務可以由 hasattr() 和 getattr() 函式來完成。
- isinstance() 函式測試物件,以確定它是否是某個特定型別或定製類的例項。
其他可以參考部落格:blog.csdn.net/qq_34979346…
第5題:什麼是python猴子補丁python monkey patch?
monkey patch (猴子補丁) 用來在執行時動態修改已有的程式碼,而不需要修改原始程式碼。
在Python中,術語monkey補丁僅指run-time上的類或模組的動態修改
>>> class A:
def func(self):
print("Hi")
>>> def monkey(self):
print("Hi, monkey")
>>> m.A.func = monkey
>>> a = m.A()
>>> a.func()
Hi, monkey
複製程式碼
公眾賬號:非本科程式設計師,來吧
微信搜尋htmlhttp
就能找到不一樣的精彩