Python面試基礎題十大陷阱,你中招了嗎?
我們在會碰到各種各樣的面試,有的甚至是HR專門為你設定的障礙,在python面試中也是,無論你是應聘Python web開發,爬蟲工程師,或是資料分析,還是自動化運維,這些python面試基礎題十大陷阱也許你會遇到,今天的python培訓總結出來給你以防萬一,收好不謝!
問題1:請問如何修改以下Python程式碼,使得下面的程式碼呼叫類A的show方法?
class A(object) def show(self): print 'derived show' class B(A) def show(self): print 'derived show' obj=B() obj.show()
答:這道題的考點是類繼承,只要通過__class__ 方法指定類物件就可以了。補充的程式碼如下:
obj._class_=A
obj.show()
問題2:請問如何修改以下Python程式碼,使得程式碼能夠執行?
class A(object):
def _init_ (self,a,b):
self._a = a
self._b = b
def myprint(self):
print 'a=',self._a,'b=',self._b
a1=A(10,20)
a1.myprint()
a1=(80)
答:此題考察得是方法物件,為了能讓物件例項能被直接呼叫,需要實現 __call__ 方法,補充程式碼如下:
class A(object):
def _init_ (self,a,b):
self._a = a
self._b = b
def myprint(self):
print 'a=',self._a,'b=',self._b
def_call_(self,num):
print'call:',num+self._a
問題3:下面這段程式碼的輸出是什麼?
class B(object): def fn(self): print"B fn" def_init_(self): print"B INIT" class A(object): def fn(self): print"A fn" def_new_(cls,a): print"NEW",a if a>10: return super(A,cls)._new_(cls) return B() def_init_(self,a): print "INIT",a a1=A(5) a1,fn() a2=A(20) a2,fn()
答:
NEW 5
B INIT
B fn
NEW 20
INIT 20
A fn
此題考察的是new和init的用法,使用 __new__ 方法,可以決定返回那個物件,也就是建立物件之前呼叫的,這個常見於於設計模式的單例、工廠模式。__init__ 是建立物件是呼叫的。
問題4:下面這段程式碼輸出什麼?
1s=[1,2,3,4]
list1 =[i for i in ls if i>2
print list1
list2 =[1*2 for i in ls if 1>2
print list2
dicl={x: x**2 for x in(2, 4, 6)}
print dic1
dic2={x: ' item'+ str(x**2)for x in (2, 4, 6)}
print dic2
setl ={x for x in 'hello world' if x not in 'low level'}
print set1
答:
[3,4]
[6,8]
{2:4,4:16,6:36}
{2:'item4',4:'item16’,6:'item36"}
set(["h",'r','d"])
此題考察的是列表和字典的生成。
問題5:下面這段程式碼輸出什麼?
num= 9
def f1():
um=20
def f2():
print num
f2()
f1()
f2()
答:
9
9
此題考察全域性變數和區域性變數。num 不是個全域性變數,所以每個函式都得到了自己的 num 拷貝,如果你想修改 num ,則必須用 global 關鍵字宣告。比如下面這樣
num=9
def f1():
global num
um=20
def f2():
print num
f2()
f1()
f2()
#prints:
#9
#20
問題6:如何使用一行程式碼交換兩個變數值?
a=8
b=9
答:
(a,b)=(b,a)
問題7:如何新增程式碼,使得沒有定義的方法都呼叫mydefault方法?
class A(object):
def_init_(self,a,b):
self.a1=a
self.b1=b
print'init'
def mydefault(self):
print'default'
a1=A(10,20)
a1.fn1()
a1.fn2()
a1.fn3()
答:
class A(object):
def_init_(self,a,b):
self.a1=a
self.b1=b
print'init'
def mydefault(self):
print'default'
def_getattr_(self,name):
return self.mydefault
a1=A(10,20)
a1.fn1()
a1.fn2()
a1.fn3()
此題的考的是Python的預設方法, 只有當沒有定義的方法呼叫時,才會呼叫方法 __getattr__。當 fn1 方法傳入引數時,我們可以給 mydefault 方法增加一個 *args 不定引數來相容。
class A(object):
def_init_(self,a,b):
self.a1=a
self.b1=b
print'init'
def mydefault(self,*args):
print'default:'+str(args[0])
def_getattr_(self,name):
print"other fn:",name
return self.mydefault
a1=A(10,20)
a1.fn1(33)
a1.fn2('hello')
a1.fn3(10)
問題8:一個包裡有三個模組,mod1.py , mod2.py , mod3.py ,但使用 from demopack import * 匯入模組時,如何保證只有 mod1 、 mod3 被匯入了。
答:在包中增加 __init__.py 檔案,並在檔案中增加:
_all_=['mod1','mod3']
問題9:寫一個函式,接收整數引數 n ,返回一個函式,函式返回n和引數的積。
答:
def mulby(num):
def gn(val):
return num*val
return gn
zw=mulby(7)
print(zw(9));
問題10:請問下面的程式碼有什麼隱患?(Python2中)
def strtest1(num):
str='first'
for i in range(num):
str+="X"
return str
答:由於變數str是個不可變物件,每次迭代,python都會生成新的str物件來儲存新的字串,num越大,建立的str物件越多,記憶體消耗越大。