真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Python有哪些高頻面試題-創(chuàng)新互聯(lián)

本篇內(nèi)容主要講解“Python有哪些高頻面試題”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Python有哪些高頻面試題”吧!

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),三亞企業(yè)網(wǎng)站建設(shè),三亞品牌網(wǎng)站建設(shè),網(wǎng)站定制,三亞網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,三亞網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

一. 將字符串 “k:1 |k1:2|k2:3|k3:4”,處理成字典 {k:1,k1:2,

str1 = "k:1|k1:2|k2:3|k3:4"
def str2dict(str1):
 dict1 = {}
 for iterms in str1.split('|'):
 key,value = iterms.split(':')
 dict1[key] = value
 return dict1
#字典推導(dǎo)式
d = {k:int(v) for t in str1.split("|") for k, v in (t.split(":"), )}

二. 請按alist中元素的age由大到小排序

alist = [{'name':'a','age':20},{'name':'b','age':30},{'name':'c','age':25}]
def sort_by_age(list1):
 return sorted(alist,key=lambda x:x['age'],reverse=True)

三. 下面代碼的輸出結(jié)果將是什么?

list = ['a','b','c','d','e']
print(list[10:])

代碼將輸出[],不會產(chǎn)生IndexError錯誤,就像所期望的那樣,嘗試用超出成員的個數(shù)的index來獲取某個列表的成員。例如,嘗試獲取list[10]和之后的成員,會導(dǎo)致IndexError。然而,嘗試獲取列表的切片,開始的index超過了成員個數(shù)不會產(chǎn)生IndexError,而是僅僅返回一個空列表。這成為特別讓人惡心的疑難雜癥,因為運行的時候沒有錯誤產(chǎn)生,導(dǎo)致Bug很難被追蹤到。

四. 寫一個列表生成式,產(chǎn)生一個公差為11的等差數(shù)列

print([x*11 for x in range(10)])

五. 給定兩個列表,怎么找出他們相同的元素和不同的元素?

list1 = [1,2,3]
list2 = [3,4,5]
set1 = set(list1)
set2 = set(list2)
print(set1 & set2)
print(set1 ^ set2)

六. 請寫出一段python代碼實現(xiàn)刪除list里面的重復(fù)元素?

l1 = ['b','c','d','c','a','a']
l2 = list(set(l1))
print(l2)

用list類的sort方法:

l1 = ['b','c','d','c','a','a']
l2 = list(set(l1))
l2.sort(key=l1.index)
print(l2)

也可以這樣寫:

l1 = ['b','c','d','c','a','a']
l2 = sorted(set(l1),key=l1.index)
print(l2)

也可以用遍歷:

l1 = ['b','c','d','c','a','a']
l2 = []
for i in l1:
 if not i in l2:
 l2.append(i)
print(l2)

七. 給定兩個list A,B ,請用找出A,B中相同與不同的元素

A,B 中相同元素: print(set(A)&set(B))
A,B 中不同元素: print(set(A)^set(B))

八. python新式類和經(jīng)典類的區(qū)別?

a. 在python里凡是繼承了object的類,都是新式類

b. Python3里只有新式類

c. Python2里面繼承object的是新式類,沒有寫父類的是經(jīng)典類

d. 經(jīng)典類目前在Python里基本沒有應(yīng)用

九. python中內(nèi)置的數(shù)據(jù)結(jié)構(gòu)有幾種?

a. 整型 int、 長整型 long、浮點型 float、 復(fù)數(shù) complex

b. 字符串 str、 列表 list、 元祖 tuple

c. 字典 dict 、 集合 set

d. Python3 中沒有 long,只有無限精度的 int

十. python如何實現(xiàn)單例模式?請寫出兩種實現(xiàn)方式?

第一種方法:使用裝飾器

def singleton(cls):
 instances = {}
 def wrapper(*args, **kwargs):
 if cls not in instances:
 instances[cls] = cls(*args, **kwargs)
 return instances[cls]
 return wrapper
 
 
@singleton
class Foo(object):
 pass
foo1 = Foo()
foo2 = Foo()
print(foo1 is foo2) # True

第二種方法:使用基類

New 是真正創(chuàng)建實例對象的方法,所以重寫基類的new 方法,以此保證創(chuàng)建對象的時候只生成一個實例

class Singleton(object):
 def __new__(cls, *args, **kwargs):
 if not hasattr(cls, '_instance'):
 cls._instance = super(Singleton, cls).__new__(cls, *args, **kwargs)
 return cls._instance
 
 
class Foo(Singleton):
 pass
foo1 = Foo()
foo2 = Foo()
print(foo1 is foo2) # True

第三種方法:元類,元類是用于創(chuàng)建類對象的類,類對象創(chuàng)建實例對象時一定要調(diào)用call方法,因此在調(diào)用call時候保證始終只創(chuàng)建一個實例即可,type是python的元類

class Singleton(type):
 def __call__(cls, *args, **kwargs):
 if not hasattr(cls, '_instance'):
 cls._instance = super(Singleton, cls).__call__(*args, **kwargs)
 return cls._instance
# Python2
class Foo(object):
 __metaclass__ = Singleton
# Python3
class Foo(metaclass=Singleton):
 pass
foo1 = Foo()
foo2 = Foo()
print(foo1 is foo2) # True

到此,相信大家對“Python有哪些高頻面試題”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


文章標題:Python有哪些高頻面試題-創(chuàng)新互聯(lián)
本文網(wǎng)址:http://weahome.cn/article/cephpp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部