python面試題大全(二)
最近開始整理python的資料,博主建立了一個qq羣,希望給大家提供一個交流的同平臺 938587844 。
22.Python如何定義一個函數?
定義函數的格式是: def functionName(arg):
23.有沒有一個工具可以幫助查找python的bug和進行靜態的代碼分析?
pycheck pylint
24.如何在一個function裏面設置一個全局的變量?
global
25.有兩個序列a,b,大小都爲n,序列元素的值任意×××數,無序;
要求:通過交換a,b中的元素,使[序列a元素的和]與[序列b元素的和]之間的差最小。
- 分別計算a,b序列的和;
- 求a序列和與b序列和的差值的一半,記爲half;
- 在和值大的序列中找出一個與和值小的序列中的元素max的差值最接近half的元素,記爲min;
- 將max與min互換即可。
26.如何用Python刪除一個文件?
使用os.remove(filename)或者os.unlink(filename);
27.Python如何copy一個文件?
shutil模塊有一個copyfile函數可以實現文件拷貝
28.python程序中文輸出問題怎麼解決?
用encode和decode
如:
import os.path
import xlrd,sys
Filename=’/home/tom/Desktop/1234.xls’
if not os.path.isfile(Filename):
raise NameError,”%s is not a valid filename”%Filename
bk=xlrd.open_workbook(Filename)
shxrange=range(bk.nsheets)
print shxrange
for x in shxrange:
p=bk.sheets()[x].name.encode(‘utf-8′)
print p.decode(‘utf-8′)
方法二:
在文件開頭加上
reload(sys)
sys.setdefaultencoding(‘utf8′)
29.python代碼得到列表list的交集與差集
交集
b1=[1,2,3]
b2=[2,3,4]
b3 = [val for val in b1 if val in b2]
print b3
差集
b1=[1,2,3]
b2=[2,3,4]
b3 = [val for val in b1 if val not in b2]
print b3
最近開始整理python的資料,博主建立了一個qq羣,希望給大家提供一個交流的同平臺 938587844 。
30.寫一個簡單的python socket編程
python 編寫server的步驟:
- 第一步是創建socket對象。調用socket構造函數。如:
socket = socket.socket( family, type )
family參數代表地址家族,可爲AF_INET或AF_UNIX。AF_INET家族包括Internet地址,AF_UNIX家族用於同一臺機器上的進程間通信。
type參數代表套接字類型,可爲SOCK_STREAM(流套接字)和SOCK_DGRAM(數據報套接字)。 - 第二步是將socket綁定到指定地址。這是通過socket對象的bind方法來實現的:
socket.bind( address )
由AF_INET所創建的套接字,address地址必須是一個雙元素元組,格式是(host,port)。host代表主機,port代表端口號。如果端口號正在使用、主機名不正確或端口已被保留,bind方法將引發socket.error異常。 - 第三步是使用socket套接字的listen方法接收連接請求。
socket.listen( backlog )
backlog指定最多允許多少個客戶連接到服務器。它的值至少爲1。收到連接請求後,這些請求需要排隊,如果隊列滿,就拒絕請求。 - 第四步是服務器套接字通過socket的accept方法等待客戶請求一個連接。
connection, address = socket.accept()
調用accept方法時,socket會進入“waiting”狀態。客戶請求連接時,方法建立連接並返回服務器。accept方法返回一個含有兩個元素的元組(connection,address)。第一個元素connection是新的socket對象,服務器必須通過它與客戶通信;第二個元素 address是客戶的Internet地址。 - 第五步是處理階段,服務器和客戶端通過send和recv方法通信(傳輸 數據)。服務器調用send,並採用字符串形式向客戶發送信息。send方法返回已發送的字符個數。服務器使用recv方法從客戶接收信息。調用recv 時,服務器必須指定一個整數,它對應於可通過本次方法調用來接收的最大數據量。recv方法在接收數據時會進入“blocked”狀態,最後返回一個字符 串,用它表示收到的數據。如果發送的數據量超過了recv所允許的,數據會被截短。多餘的數據將緩衝於接收端。以後調用recv時,多餘的數據會從緩衝區 刪除(以及自上次調用recv以來,客戶可能發送的其它任何數據)。
- 傳輸結束,服務器調用socket的close方法關閉連接。
python編寫client的步驟:
- 創建一個socket以連接服務器:socket = socket.socket( family, type )
- 使用socket的connect方法連接服務器。對於AF_INET家族,連接格式如下:
socket.connect( (host,port) )
host代表服務器主機名或IP,port代表服務器進程所綁定的端口號。如連接成功,客戶就可通過套接字與服務器通信,如果連接失敗,會引發socket.error異常。 - 處理階段,客戶和服務器將通過send方法和recv方法通信。
- 傳輸結束,客戶通過調用socket的close方法關閉連接。
下面給個簡單的例子:
server.py
#coding:utf-8
import socket
if __name__ == '__main__':
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.bind(('localhost', 8001))
sock.listen(5)
while True:
connection,address = sock.accept()
try:
connection.settimeout(5)
buf = connection.recv(1024)
if buf == '1':
connection.send('welcome to server!')
else:
connection.send('please go out!')
except socket.timeout:
print 'time out'
connection.close()
client.py
#coding:utf-8
import socket
import time
if __name__ == '__main__':
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect(('localhost', 8001))
time.sleep(2)
sock.send('1')
print sock.recv(1024)
sock.close()
在終端運行server.py,然後運行clien.py,會在終端打印“welcome to server!"。
31.python如何捕獲異常
(1)使用try和except語句來捕獲異常
try:
block
except [exception,[data…]]:
block
try:
block
except [exception,[data...]]:
block
else:
block
捕獲到的IOError錯誤的詳細原因會被放置在對象e中,然後運行該python 異常處理的except代碼塊捕獲所有的異常
(2)用raise語句手工引發一個異常:
raise [exception[,data]]
try:
raise MyError #自己拋出一個異常
except MyError:
print 'a error'
raise ValueError,’invalid argument’
(3)採用sys模塊回溯最後的異常
import sys
try:
block
except:
info=sys.exc_info()
print info[0],":",info[1]
32.src = "security/afafsff/?ip=123.4.56.78&id=45",請寫一段代碼用正則匹配出ip
匹配ip地址的python正則表達式
pattern =<br/>'^([01]?\d\d?|2[0-4]\d|25[0-5])\.([01]?\d\d?|2[0-4]\d|25[0-5])\.([01]?\d\d?|2[0-4]\d|25[0-5])\.([01]?\d\d?|2[0-4]\d|25[0-5])$'
故本題答案
>>> re.findall(r'([01]?\d\d?|2[0-4]\d|25[0-5])\.([01]?\d\d?|2[0-4]\d|25[0-5])\.([01]?\d\d?|2[0-4]\d|25[0-5])\.([01]?\d\d?|2[0-4]\d|25[0-5])', src)
[('123', '4', '56', '78')]
33.寫一段代碼用json數據的處理方式獲取{"persons":[{"name":"yu","age":"23"},{"name":"zhang","age":"34"}]}這一段json中第一個人的名字。
json讀取
>>> import json
>>> j = json.loads('{"persons":[{"name":"yu","age":"23"},{"name":"zhang","age":"34"}]}')
>>> print j
{u'persons': [{u'age': u'23', u'name': u'yu'}, {u'age': u'34', u'name': u'zhang'}]}
>>> print j.keys()
[u'persons']
>>> print j.values()
[[{u'age': u'23', u'name': u'yu'}, {u'age': u'34', u'name': u'zhang'}]]
>>> print j.values()[0]
[{u'age': u'23', u'name': u'yu'}, {u'age': u'34', u'name': u'zhang'}]
>>> print j.values()[0][0]
{u'age': u'23', u'name': u'yu'}
>>> print j.values()[0][0]['name']
yu
34.平衡點問題
平衡點:比如int[] numbers = {1,3,5,7,8,25,4,20}; 25前面的總和爲24,25後面的總和也是24,25這個點就是平衡點;假如一個數組中的元素,其前面的部分等於後面的部分,那麼這個點的位序就是平衡點
要求:返回任何一個平衡點
使用sum函數累加所有的數。
使用一個變量fore來累加序列的前部。直到滿足條件fore<(total-number)/2;
python代碼如下:
numbers = [1,3,5,7,8,2,4,20]
#find total
total=sum(numbers)
#find num
fore=0
for number in numbers:
if fore<(total-number)/2 :
fore+=number
else:
break
#print answer
if fore == (total-number)/2 :
print number
else :
print r'not found'
算法簡單,而且是O(n)的,12行代碼搞定。
35.支配點問題:
支配數:數組中某個元素出現的次數大於數組總數的一半時就成爲支配數,其所在位序成爲支配點;比如int[] a = {3,3,1,2,3};3爲支配數,0,1,4分別爲支配點;
要求:返回任何一個支配點
li = [3,3,1,2,3]
def main():
mid = len(li)/2
for l in li:
count = 0
i = 0
mark = 0
while True:
if l == li[i]:
count += 1
temp = i
i += 1
if count > mid:
mark = temp
return (mark,li[mark])
if i > len(li) - 1:
break
if __name__ == "__main__":
print main()
【搜索圓方圓,獲得“python教程”,“python下載”,“python入門”類相關信息。】