python面試題大全(二)

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元素的和]之間的差最小。

  1. 分別計算a,b序列的和;
  2. 求a序列和與b序列和的差值的一半,記爲half;
  3. 在和值大的序列中找出一個與和值小的序列中的元素max的差值最接近half的元素,記爲min;
  4. 將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的步驟:

  1. 第一步是創建socket對象。調用socket構造函數。如:
    socket = socket.socket( family, type )
    family參數代表地址家族,可爲AF_INET或AF_UNIX。AF_INET家族包括Internet地址,AF_UNIX家族用於同一臺機器上的進程間通信。
    type參數代表套接字類型,可爲SOCK_STREAM(流套接字)和SOCK_DGRAM(數據報套接字)。
  2. 第二步是將socket綁定到指定地址。這是通過socket對象的bind方法來實現的:
    socket.bind( address )
    由AF_INET所創建的套接字,address地址必須是一個雙元素元組,格式是(host,port)。host代表主機,port代表端口號。如果端口號正在使用、主機名不正確或端口已被保留,bind方法將引發socket.error異常。
  3. 第三步是使用socket套接字的listen方法接收連接請求。
    socket.listen( backlog )
    backlog指定最多允許多少個客戶連接到服務器。它的值至少爲1。收到連接請求後,這些請求需要排隊,如果隊列滿,就拒絕請求。
  4. 第四步是服務器套接字通過socket的accept方法等待客戶請求一個連接。
    connection, address = socket.accept()
      調用accept方法時,socket會進入“waiting”狀態。客戶請求連接時,方法建立連接並返回服務器。accept方法返回一個含有兩個元素的元組(connection,address)。第一個元素connection是新的socket對象,服務器必須通過它與客戶通信;第二個元素 address是客戶的Internet地址。
  5. 第五步是處理階段,服務器和客戶端通過send和recv方法通信(傳輸 數據)。服務器調用send,並採用字符串形式向客戶發送信息。send方法返回已發送的字符個數。服務器使用recv方法從客戶接收信息。調用recv 時,服務器必須指定一個整數,它對應於可通過本次方法調用來接收的最大數據量。recv方法在接收數據時會進入“blocked”狀態,最後返回一個字符 串,用它表示收到的數據。如果發送的數據量超過了recv所允許的,數據會被截短。多餘的數據將緩衝於接收端。以後調用recv時,多餘的數據會從緩衝區 刪除(以及自上次調用recv以來,客戶可能發送的其它任何數據)。
  6. 傳輸結束,服務器調用socket的close方法關閉連接。

python編寫client的步驟:

  1. 創建一個socket以連接服務器:socket = socket.socket( family, type )
  2. 使用socket的connect方法連接服務器。對於AF_INET家族,連接格式如下:
    socket.connect( (host,port) )
    host代表服務器主機名或IP,port代表服務器進程所綁定的端口號。如連接成功,客戶就可通過套接字與服務器通信,如果連接失敗,會引發socket.error異常。
  3. 處理階段,客戶和服務器將通過send方法和recv方法通信。
  4. 傳輸結束,客戶通過調用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入門”類相關信息。】

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