當前位置:首頁 » 編程語言 » python開發面試題

python開發面試題

發布時間: 2025-09-07 14:02:31

A. python web框架django面試題收藏

在深入探索Django框架及其在Web開發中的應用之前,了解Django的常見面試題是必要的。以下問題涵蓋了從基礎概念到實際應用的各個方面,幫助你准備Django的面試。

1. 對Django的認識?

2. Django、Flask、Tornado之間的對比。

3. wsgi、uwsgi、uWSGI的解釋。

4. Django請求生命周期的概述。

5. FBV與CBV簡述。

6. 添加裝飾器給CBV程序的方法。

7. MVC與MTV的區別。

8. Django路由系統中name的作用。

9. 列出Django的內置組件。

10. Django MIDDLEWARES中間件的作用與應用場景。

11. 列舉Django中間件的五個方法。

12. Django請求對象的創建時間。

13. Django重定向的實現及使用的狀態碼。

14. XSS攻擊的簡介。

15. Django中CSRF的實現機制。

16. 使用AJAX發送POST請求時,攜帶CSRF token的常用方法。

17. Django runserver與uWSGI的區別。

18. Cookie與Session的區別。

19. Django ORM中QuerySet對象的所有方法。

20. only與defer的區別。

21. select_related與prefetch_related的區別。

22. filter與exclude的區別。

23. F與Q的作用。

24. values與values_list的區別。

25. 使用ORM批量創建數據的途徑。

26. Django中的Form與ModelForm的作用。

27. 實現數據源實時更新的兩種方式。

28. ForeignKey欄位中on_delete參數的解釋。

29. 列出三種能寫SQL語句的ORM方法。

30. 如何設置Django ORM的讀寫分離。

31. 實現ORM表中添加數據時創建日誌記錄的方法。

32. Django內置的緩存機制。

33. 配置Django使用Redis作為緩存。

34. 模板中filter與simple_tag的區別。

35. Django Debug Toolbar的功能。

36. 實現Django單元測試的步驟。

37. ORM中db first與code first的含義。

38. 根據資料庫表生成model中的類。

39. ORM與原生SQL的優缺點。

40. Django contenttype組件的作用。

41. 對RESTful規范的理解。

42. 介面的冪等性概念。

43. RPC(遠程過程調用)的介紹。

44. 使用API的原因。

45. 為何選擇Django REST Framework框架。

46. Django REST Framework框架中的組件。

47. 視圖可以繼承的REST Framework類。

48. REST Framework框架的認證流程概覽。

49. 實現用戶訪問頻率控制的方法。

50. 序列化組件的作用及外鍵關系的鉤子方法。

51. 提供介面前的准備工作。

52. PV與UV的定義。

53. 跨域的解釋與解決策略。

54. 實現用戶登錄認證的步驟。

55. 將字典轉換為URL格式的方法。

以上內容涵蓋了Django的多個核心概念和功能,希望對你在學習和面試過程中有所幫助。

B. 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對象越多,內存消耗越大。

C. python面試必備題目有哪些

Q:你做一個自我介紹吧?
旁白:其實遇到好幾家面試官都讓我做自我介紹了,該如何自我介紹陽哥估計都會背了,好玩(惡心)的是在萬達信息面試,面試了3個技術官,每個人都分別讓我做了自我介紹,尼瑪,他們3個就不會溝通一下要問我啥嗎,一個問題至於問我3遍嗎~:funk:陽哥是敢怒不敢言,畢竟在人家的地盤。
PS:自我介紹的內容就不說了,每個人都是獨特的,我就跟大家說一下應該如何自我介紹吧。
一個優良的自我介紹會給面試官留下深刻的印象,大部分情況下,所謂的面試好壞其實看的就是你給面試官留下的印象怎麼樣了,我們用俗語叫感覺。
自我介紹應該分以下幾個部分,按照一定的邏輯連貫起來。如果連貫不起來,或者不夠熟練一定在台下多背幾遍,多講幾遍,但是面試的時候不要說的跟背過似的,高境界就是讓面試官感覺你是臨場發揮的,卻又比背的都好。
1)個人基本信息(姓名、年齡、老家、居住地等)
2)自己來自哪裡(工作地點),是干什麼的(給自己一個清晰的定位,比如:我是一名Android開發工程師),擔任過什麼職務、做過什麼樣的項目
3)自己為何來貴公司面試
4)最後祝願(希望能得到貴公司的認可等等,不用太多,一兩句話就ok)
Q:介紹一下你做過的項目吧?
PS:黑馬那麼多項目,隨便准備3個就ok了。
介紹項目大概的思路如下:
1)這個項目是干什麼的(比如是一個類似網易新聞的地方新聞客戶端,或者類似美團的o2o,或者類似豌豆莢的一個應用市場,或者類似淘寶的購物平台)?解釋就是拿一個市場上耳熟能詳的應用跟自己的應用做類比,省的面試官聽的雲里霧里的。
2)自己負責了哪些模塊(功能)的職責(比如負責系統的架構,核心代碼的編寫,xx功能模塊的開發等等)
3)自己在這個項目中擔當的責任(比如,這個項目是自己獨立開發的,這個項目是和另外一個同事一起架構一起開發的,這個項目是自己負責了幾個核心模塊)
4)項目中都用到了哪些技術
5)從項目中學到了哪些東西(可以從技術方向和業務兩個方向入手)
旁白:面試官問的很多技術性問題跟之前問的都大同小異,因此這里只給出有特色且技術含量高的。陽哥正在寫面試寶典,該寶典核心內容針對的還是技術問題,陽哥會從javase基礎到javase高級,從Android基礎到Android高級以及到Android項目依次展開分析,其次也會寫一些常見的非技術性問題,敬請期待~
Q:①在Listview的優化中,我們為何使用ConvertView?②為何使用ViewHolder?③你認為哪個更能解決問題?④你認為view.inflate和view.findviewById哪個更耗時,為什麼?⑤如果這兩個AP讓你重新寫,你怎麼寫?
PS:上面的問題,陽哥認為是面試以來遇到很難的一個,也是很有技術含量的一道題。前一半問題還好回答,最後一個問題真的需要發揮想像了。
A:①使用ConvertView可以實現對view的復用,這樣大大節約了每次創建對象的時間,提升了ListView的顯示效率。②使用ViewHolder作為內部類,可以將view的子控制項封裝在ViewHolder類中,然後通過View.setTag(ViewHolder)將view和ViewHolder進行綁定,這樣我們就不用每次都調用view的findViewById(id)方法來查找控制項。③使用ConvertView解決了一大部分問題,使用ViewHolder實現了控制項換時間的問題,因為給View對象設置一個Tag本身就是佔用內存的,因此ViewHolder的使用還是需要區分不同的應用場景的, 沒有絕對的好與不好。如果內存足夠需要高效則ViewHolder建議使用,否則不建議使用。④當然是view.inflate耗時,這個函數完成的功能是把xml布局文件通過pullParser的形式給解析到內存中,需要io,需要遞歸子節點。⑤我其實還不太相信我寫出來的代碼比Google官方寫的好,如果讓我寫的話我可能會這樣考慮,當用戶在使用view.inflate的時候將多個id作為數組添加到形參中,這樣在初始化view的使用我就可以給這個view直接調用setTag方法綁定需要的子控制項。不過這個原生方法其實也應該保留共不同的需求使用。
PS:技術面試時間並不長,我回答了幾個之後,他們兩個大眼瞪小眼,A看看B問:你還有什麼問的嗎?B說我沒有,你還有嗎?A說我也沒了。那行,接下來,他們就讓我等人事了。

熱點內容
linux關閉開機啟動 發布:2025-09-07 17:59:19 瀏覽:95
python寫入中文 發布:2025-09-07 17:59:10 瀏覽:429
pythonwith的用法 發布:2025-09-07 17:58:37 瀏覽:654
存儲器機構 發布:2025-09-07 17:58:28 瀏覽:519
安撫又解壓 發布:2025-09-07 17:53:35 瀏覽:926
在線編輯php 發布:2025-09-07 17:52:59 瀏覽:806
手機叉叉助手本地腳本 發布:2025-09-07 17:47:20 瀏覽:293
linux輸入命令行 發布:2025-09-07 17:31:49 瀏覽:220
android文件監聽 發布:2025-09-07 17:22:32 瀏覽:364
英國伺服器租用地址 發布:2025-09-07 17:13:54 瀏覽:810