來(lái)源于 微信公眾號(hào): python爬蟲人工智能大數(shù)據(jù)
1、一行代碼實(shí)現(xiàn)1--100之和
利用sum()函數(shù)求和
2啰脚、如何在一個(gè)函數(shù)內(nèi)部修改全局變量
函數(shù)內(nèi)部global聲明 修改全局變量
3、列出5個(gè)python標(biāo)準(zhǔn)庫(kù)
os:提供了不少與操作系統(tǒng)相關(guān)聯(lián)的函數(shù)
sys: 通常用于命令行參數(shù)
re: 正則匹配
math: 數(shù)學(xué)運(yùn)算
datetime:處理日期時(shí)間
4耐量、字典如何刪除鍵和合并兩個(gè)字典
del和update方法
5、談下python的GIL
GIL 是python的全局解釋器鎖鲤竹,同一進(jìn)程中假如有多個(gè)線程運(yùn)行搅方,一個(gè)線程在運(yùn)行python程序的時(shí)候會(huì)霸占python解釋器(加了一把鎖即GIL)盟蚣,使該進(jìn)程內(nèi)的其他線程無(wú)法運(yùn)行,等該線程運(yùn)行完后其他線程才能運(yùn)行节沦。如果線程運(yùn)行過(guò)程中遇到耗時(shí)操作键思,則解釋器鎖解開(kāi),使其他線程運(yùn)行甫贯。所以在多線程中吼鳞,線程的運(yùn)行仍是有先后順序的,并不是同時(shí)進(jìn)行叫搁。
多進(jìn)程中因?yàn)槊總€(gè)進(jìn)程都能被系統(tǒng)分配資源赔桌,相當(dāng)于每個(gè)進(jìn)程有了一個(gè)python解釋器供炎,所以多進(jìn)程可以實(shí)現(xiàn)多個(gè)進(jìn)程的同時(shí)運(yùn)行,缺點(diǎn)是進(jìn)程系統(tǒng)資源開(kāi)銷大
6疾党、python實(shí)現(xiàn)列表去重的方法
先通過(guò)集合去重音诫,在轉(zhuǎn)列表
7、fun(args,kwargs)中的args,**kwargs什么意思雪位?
8竭钝、python2和python3的range(100)的區(qū)別
python2返回列表,python3返回迭代器雹洗,節(jié)約內(nèi)存
9香罐、一句話解釋什么樣的語(yǔ)言能夠用裝飾器?
函數(shù)可以作為參數(shù)傳遞的語(yǔ)言,可以使用裝飾器
10时肿、python內(nèi)建數(shù)據(jù)類型有哪些
整型--int
布爾型--bool
字符串--str
列表--list
元組--tuple
字典--dict
11庇茫、簡(jiǎn)述面向?qū)ο笾?strong>new和init區(qū)別
init是初始化方法,創(chuàng)建對(duì)象后螃成,就立刻被默認(rèn)調(diào)用了旦签,可接收參數(shù),如圖
1锈颗、new至少要有一個(gè)參數(shù)cls顷霹,代表當(dāng)前類咪惠,此參數(shù)在實(shí)例化時(shí)由Python解釋器自動(dòng)識(shí)別
2击吱、new必須要有返回值,返回實(shí)例化出來(lái)的實(shí)例遥昧,這點(diǎn)在自己實(shí)現(xiàn)new時(shí)要特別注意覆醇,可以return父類(通過(guò)super(當(dāng)前類名, cls))new出來(lái)的實(shí)例,或者直接是object的new出來(lái)的實(shí)例
3炭臭、init有一個(gè)參數(shù)self永脓,就是這個(gè)new返回的實(shí)例,init在new的基礎(chǔ)上可以完成一些其它初始化的動(dòng)作鞋仍,init不需要返回值
4常摧、如果new創(chuàng)建的是當(dāng)前類的實(shí)例,會(huì)自動(dòng)調(diào)用init函數(shù)威创,通過(guò)return語(yǔ)句里面調(diào)用的new函數(shù)的第一個(gè)參數(shù)是cls來(lái)保證是當(dāng)前類實(shí)例落午,如果是其他類的類名,肚豺;那么實(shí)際創(chuàng)建返回的就是其他類的實(shí)例溃斋,其實(shí)就不會(huì)調(diào)用當(dāng)前類的init函數(shù),也不會(huì)調(diào)用其他類的init函數(shù)吸申。
12梗劫、簡(jiǎn)述with方法打開(kāi)處理文件幫我我們做了什么享甸?
打開(kāi)文件在進(jìn)行讀寫的時(shí)候可能會(huì)出現(xiàn)一些異常狀況,如果按照常規(guī)的f.open
寫法梳侨,我們需要try,except,finally蛉威,做異常判斷,并且文件最終不管遇到什么情況走哺,都要執(zhí)行finally f.close()關(guān)閉文件瓷翻,with方法幫我們實(shí)現(xiàn)了finally中f.close
(當(dāng)然還有其他自定義功能,有興趣可以研究with方法源碼)
13割坠、列表[1,2,3,4,5],請(qǐng)使用map()函數(shù)輸出[1,4,9,16,25]齐帚,并使用列表推導(dǎo)式提取出大于10的數(shù),最終輸出[16,25]
map()函數(shù)第一個(gè)參數(shù)是fun彼哼,第二個(gè)參數(shù)是一般是list对妄,第三個(gè)參數(shù)可以寫list,也可以不寫敢朱,根據(jù)需求14剪菱、python中生成隨機(jī)整數(shù)、隨機(jī)小數(shù)拴签、0--1之間小數(shù)方法
隨機(jī)整數(shù):random.randint(a,b),生成區(qū)間內(nèi)的整數(shù)
隨機(jī)小數(shù):習(xí)慣用numpy庫(kù)孝常,利用np.random.randn(5)生成5個(gè)隨機(jī)小數(shù)
0-1隨機(jī)小數(shù):random.random(),括號(hào)中不傳參
15、避免轉(zhuǎn)義給字符串加哪個(gè)字母表示原始字符串蚓哩?
r , 表示需要原始字符串构灸,不轉(zhuǎn)義特殊字符
16、<div class="nam">中國(guó)</div>岸梨,用正則匹配出標(biāo)簽里面的內(nèi)容(“中國(guó)”)喜颁,其中class的類名是不確定的
17、python中斷言方法舉例
assert()方法曹阔,斷言成功半开,則程序繼續(xù)執(zhí)行,斷言失敗赃份,則程序報(bào)錯(cuò)
18寂拆、數(shù)據(jù)表student有id,name,score,city字段,其中name中的名字可有重復(fù)抓韩,需要消除重復(fù)行,請(qǐng)寫sql語(yǔ)句
select distinct name from student
19纠永、10個(gè)Linux常用命令
ls pwd cd touch rm mkdir tree cp mv cat more grep echo
20、python2和python3區(qū)別园蝠?列舉5個(gè)
1渺蒿、Python3 使用 print 必須要以小括號(hào)包裹打印內(nèi)容,比如 print('hi')
Python2 既可以使用帶小括號(hào)的方式彪薛,也可以使用一個(gè)空格來(lái)分隔打印內(nèi)容茂装,比如 print 'hi'
2怠蹂、python2 range(1,10)返回列表,python3中返回迭代器少态,節(jié)約內(nèi)存
3城侧、python2中使用ascii編碼,python中使用utf-8編碼
4彼妻、python2中unicode表示字符串序列嫌佑,str表示字節(jié)序列
python3中str表示字符串序列,byte表示字節(jié)序列
5侨歉、python2中為正常顯示中文屋摇,引入coding聲明,python3中不需要
6幽邓、python2中是raw_input()函數(shù)炮温,python3中是input()函數(shù)
21、列出python中可變數(shù)據(jù)類型和不可變數(shù)據(jù)類型牵舵,并簡(jiǎn)述原理
不可變數(shù)據(jù)類型:數(shù)值型柒啤、字符串型string和元組tuple
不允許變量的值發(fā)生變化,如果改變了變量的值畸颅,相當(dāng)于是新建了一個(gè)對(duì)象担巩,而對(duì)于相同的值的對(duì)象,在內(nèi)存中則只有一個(gè)對(duì)象(一個(gè)地址)没炒,如下圖用id()方法可以打印對(duì)象的id
可變數(shù)據(jù)類型:列表list和字典dict涛癌;
允許變量的值發(fā)生變化,即如果對(duì)變量進(jìn)行append窥浪、+=等這種操作后祖很,只是改變了變量的值,而不會(huì)新建一個(gè)對(duì)象漾脂,變量引用的對(duì)象的地址也不會(huì)變化,不過(guò)對(duì)于相同的值的不同對(duì)象胚鸯,在內(nèi)存中則會(huì)存在不同的對(duì)象骨稿,即每個(gè)對(duì)象都有自己的地址,相當(dāng)于內(nèi)存中對(duì)于同值的對(duì)象保存了多份姜钳,這里不存在引用計(jì)數(shù)坦冠,是實(shí)實(shí)在在的對(duì)象。
22哥桥、s = "ajldjlajfdljfddd"辙浑,去重并從小到大排序輸出"adfjl"
set去重,去重轉(zhuǎn)成list,利用sort方法排序拟糕,reeverse=False是從小到大排
list是不 變數(shù)據(jù)類型判呕,s.sort時(shí)候沒(méi)有返回值倦踢,所以注釋的代碼寫法不正確
23、用lambda函數(shù)實(shí)現(xiàn)兩個(gè)數(shù)相乘
24侠草、字典根據(jù)鍵從小到大排序
dic={"name":"zs","age":18,"city":"深圳","tel":"1362626627"}
25辱挥、利用collections庫(kù)的Counter方法統(tǒng)計(jì)字符串每個(gè)單詞出現(xiàn)的次數(shù)"kjalfj;ldsjafl;hdsllfdhg;lahfbl;hl;ahlf;h"
26、字符串a(chǎn) = "not 404 found 張三 99 深圳"边涕,每個(gè)詞中間是空格晤碘,用正則過(guò)濾掉英文和數(shù)字,最終輸出"張三 深圳"
順便貼上匹配小數(shù)的代碼功蜓,雖然能匹配园爷,但是健壯性有待進(jìn)一步確認(rèn)
27、filter方法求出列表所有奇數(shù)并構(gòu)造新列表式撼,a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
filter() 函數(shù)用于過(guò)濾序列腮介,過(guò)濾掉不符合條件的元素,返回由符合條件元素組成的新列表端衰。該接收兩個(gè)參數(shù)叠洗,第一個(gè)為函數(shù),第二個(gè)為序列旅东,序列的每個(gè)元素作為參數(shù)傳遞給函數(shù)進(jìn)行判灭抑,然后返回 True 或 False,最后將返回 True 的元素放到新列表
28抵代、列表推導(dǎo)式求列表所有奇數(shù)并構(gòu)造新列表腾节,a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
29、正則re.complie作用
re.compile是將正則表達(dá)式編譯成一個(gè)對(duì)象荤牍,加快速度案腺,并重復(fù)使用
30、a=(1康吵,)b=(1)劈榨,c=("1") 分別是什么類型的數(shù)據(jù)?
31晦嵌、兩個(gè)列表[1,5,7,9]和[2,2,6,8]合并為[1,2,2,3,6,7,8,9]
extend可以將另一個(gè)集合中的元素逐一添加到列表中同辣,區(qū)別于append整體添加
32、用python刪除文件和用linux命令刪除文件方法
python:os.remove(文件名)
linux: rm 文件名
33惭载、log日志中旱函,我們需要用時(shí)間戳記錄error,warning等的發(fā)生時(shí)間,請(qǐng)用datetime模塊打印當(dāng)前時(shí)間戳 “2018-04-01 11:38:54”
順便把星期的代碼也貼上了
34描滔、數(shù)據(jù)庫(kù)優(yōu)化查詢方法
外鍵棒妨、索引、聯(lián)合查詢含长、選擇特定字段等等
35券腔、請(qǐng)列出你會(huì)的任意一種統(tǒng)計(jì)圖(條形圖伏穆、折線圖等)繪制的開(kāi)源庫(kù),第三方也行
pychart颅眶、matplotlib
36蜈出、寫一段自定義異常代碼
自定義異常用raise拋出異常
37、正則表達(dá)式匹配中涛酗,(.)和(.?)匹配區(qū)別铡原?
(.*)是貪婪匹配,會(huì)把滿足正則的盡可能多的往后匹配
(.*?)是非貪婪匹配商叹,會(huì)把滿足正則的盡可能少匹配
38燕刻、簡(jiǎn)述Django的orm
ORM,全拼Object-Relation Mapping剖笙,意為對(duì)象-關(guān)系映射
實(shí)現(xiàn)了數(shù)據(jù)模型與數(shù)據(jù)庫(kù)的解耦卵洗,通過(guò)簡(jiǎn)單的配置就可以輕松更換數(shù)據(jù)庫(kù),而不需要修改代碼只需要面向?qū)ο缶幊?orm操作本質(zhì)上會(huì)根據(jù)對(duì)接的數(shù)據(jù)庫(kù)引擎弥咪,翻譯成對(duì)應(yīng)的sql語(yǔ)句,所有使用Django開(kāi)發(fā)的項(xiàng)目無(wú)需關(guān)心程序底層使用的是MySQL过蹂、Oracle、sqlite....聚至,如果數(shù)據(jù)庫(kù)遷移酷勺,只需要更換Django的數(shù)據(jù)庫(kù)引擎即可
39、[[1,2],[3,4],[5,6]]一行代碼展開(kāi)該列表扳躬,得出[1,2,3,4,5,6]
列表推導(dǎo)式的騷操作
運(yùn)行過(guò)程:for i in a ,每個(gè)i是【1,2】脆诉,【3,4】,【5,6】贷币,for j in i击胜,每個(gè)j就是1,2,3,4,5,6,合并后就是結(jié)果
還有更騷的方法,將列表轉(zhuǎn)成numpy矩陣役纹,通過(guò)numpy的flatten()方法
40偶摔、x="abc",y="def",z=["d","e","f"],分別求出x.join(y)和x.join(z)返回的結(jié)果
join()括號(hào)里面的是可迭代對(duì)象,x插入可迭代對(duì)象中間字管,形成字符串啰挪,結(jié)果一致,有沒(méi)有突然感覺(jué)字符串的常見(jiàn)操作都不會(huì)玩了!
順便建議大家學(xué)下os.path.join()方法嘲叔,拼接路徑經(jīng)常用到,也用到了join,和字符串操作中的join有什么區(qū)別抽活,該問(wèn)題大家可以查閱相關(guān)文檔硫戈,后期會(huì)有答案
41、舉例說(shuō)明異常模塊中try except else finally的相關(guān)意義
try..except..else沒(méi)有捕獲到異常下硕,執(zhí)行else語(yǔ)句
try..except..finally不管是否捕獲到異常丁逝,都執(zhí)行finally語(yǔ)句
42汁胆、python中交換兩個(gè)數(shù)值
43、舉例說(shuō)明zip()函數(shù)用法
zip()函數(shù)在運(yùn)算時(shí)霜幼,會(huì)以一個(gè)或多個(gè)序列(可迭代對(duì)象)做為參數(shù)嫩码,返回一個(gè)元組的列表。同時(shí)將這些序列中并排的元素配對(duì)罪既。
zip()參數(shù)可以接受任何類型的序列铸题,同時(shí)也可以有兩個(gè)以上的參數(shù);當(dāng)傳入?yún)?shù)的長(zhǎng)度不同時(shí),zip能自動(dòng)以最短序列長(zhǎng)度為準(zhǔn)進(jìn)行截取琢感,獲得元組丢间。
44、a="張明 98分"驹针,用re.sub烘挫,將98替換為100
45、寫5條常用sql語(yǔ)句
show databases;
show tables;
desc 表名;
select * from 表名;
delete from 表名 where id=5;
update students set gender=0,hometown="北京" where id=5
46柬甥、a="hello"和b="你好"編碼成bytes類型
47饮六、[1,2,3]+[4,5,6]的結(jié)果是多少?
兩個(gè)列表相加苛蒲,等價(jià)于extend
48卤橄、提高python運(yùn)行效率的方法
1、使用生成器撤防,因?yàn)榭梢怨?jié)約大量?jī)?nèi)存
2虽风、循環(huán)代碼優(yōu)化,避免過(guò)多重復(fù)代碼的執(zhí)行
3寄月、核心模塊用Cython PyPy等辜膝,提高效率
4、多進(jìn)程漾肮、多線程厂抖、協(xié)程
5、多個(gè)if elif條件判斷克懊,可以把最有可能先發(fā)生的條件放到前面寫忱辅,這樣可以減少程序判斷的次數(shù),提高效率
49谭溉、簡(jiǎn)述mysql和redis區(qū)別
redis:內(nèi)存型非關(guān)系數(shù)據(jù)庫(kù)墙懂,數(shù)據(jù)保存在內(nèi)存中,速度快
mysql:關(guān)系型數(shù)據(jù)庫(kù)扮念,數(shù)據(jù)保存在磁盤中损搬,檢索的話,會(huì)有一定的Io操作,訪問(wèn)速度相對(duì)慢
50巧勤、遇到bug如何處理
1嵌灰、細(xì)節(jié)上的錯(cuò)誤,通過(guò)print()打印颅悉,能執(zhí)行到print()說(shuō)明一般上面的代碼沒(méi)有問(wèn)題沽瞭,分段檢測(cè)程序是否有問(wèn)題,如果是js的話可以alert或console.log
2剩瓶、如果涉及一些第三方框架驹溃,會(huì)去查官方文檔或者一些技術(shù)博客。
3儒搭、對(duì)于bug的管理與歸類總結(jié)吠架,一般測(cè)試將測(cè)試出的bug用teambin等bug管理工具進(jìn)行記錄,然后我們會(huì)一條一條進(jìn)行修改搂鲫,修改的過(guò)程也是理解業(yè)務(wù)邏輯和提高自己編程邏輯縝密性的方法傍药,我也都會(huì)收藏做一些筆記記錄。
4魂仍、導(dǎo)包問(wèn)題拐辽、城市定位多音字造成的顯示錯(cuò)誤問(wèn)題
51、正則匹配擦酌,匹配日期2018-03-20
仍有同學(xué)問(wèn)正則俱诸,其實(shí)匹配并不難,提取一段特征語(yǔ)句赊舶,用(.*?)匹配即可
52睁搭、list=[2,3,5,4,9,6],從小到大排序笼平,不許用sort园骆,輸出[2,3,4,5,6,9]
利用min()方法求出最小值,原列表刪除最小值寓调,新列表加入最小值锌唾,遞歸調(diào)用獲取最小值的函數(shù),反復(fù)操作
53夺英、寫一個(gè)單列模式
因?yàn)閯?chuàng)建對(duì)象時(shí)new方法執(zhí)行晌涕,并且必須return 返回實(shí)例化出來(lái)的對(duì)象所cls.__instance是否存在,不存在的話就創(chuàng)建對(duì)象痛悯,存在的話就返回該對(duì)象余黎,來(lái)保證只有一個(gè)實(shí)例對(duì)象存在(單列)掩浙,打印ID爆捞,值一樣,說(shuō)明對(duì)象同一個(gè)
54崔慧、保留兩位小數(shù)
題目本身只有a="%.03f"%1.3335,讓計(jì)算a的結(jié)果炒考,為了擴(kuò)充保留小數(shù)的思路可缚,提供round方法(數(shù)值,保留位數(shù))
55斋枢、求三個(gè)方法打印結(jié)果
fn("one",1)直接將鍵值對(duì)傳給字典帘靡;
fn("two",2)因?yàn)樽值湓趦?nèi)存中是可變數(shù)據(jù)類型,所以指向同一個(gè)地址瓤帚,傳了新的額參數(shù)后描姚,會(huì)相當(dāng)于給字典增加鍵值對(duì)
fn("three",3,{})因?yàn)閭髁艘粋€(gè)新字典,所以不再是原先默認(rèn)參數(shù)的字典
56戈次、列出常見(jiàn)的狀態(tài)碼和意義
200 OK
請(qǐng)求正常處理完畢
204 No Content
請(qǐng)求成功處理轩勘,沒(méi)有實(shí)體的主體返回
206 Partial Content
GET范圍請(qǐng)求已成功處理
301 Moved Permanently
永久重定向,資源已永久分配新URI
302 Found
臨時(shí)重定向怯邪,資源已臨時(shí)分配新URI
303 See Other
臨時(shí)重定向绊寻,期望使用GET定向獲取
304 Not Modified
發(fā)送的附帶條件請(qǐng)求未滿足
307 Temporary Redirect
臨時(shí)重定向,POST不會(huì)變成GET
400 Bad Request
請(qǐng)求報(bào)文語(yǔ)法錯(cuò)誤或參數(shù)錯(cuò)誤
401 Unauthorized
需要通過(guò)HTTP認(rèn)證悬秉,或認(rèn)證失敗
403 Forbidden
請(qǐng)求資源被拒絕
404 Not Found
無(wú)法找到請(qǐng)求資源(服務(wù)器無(wú)理由拒絕)
500 Internal Server Error
服務(wù)器故障或Web應(yīng)用故障
503 Service Unavailable
服務(wù)器超負(fù)載或停機(jī)維護(hù)
57澄步、分別從前端、后端和泌、數(shù)據(jù)庫(kù)闡述web項(xiàng)目的性能優(yōu)化
該題目網(wǎng)上有很多方法村缸,我不想截圖網(wǎng)上的長(zhǎng)串文字,看的頭疼武氓,按我自己的理解說(shuō)幾點(diǎn)
前端優(yōu)化:
1梯皿、減少http請(qǐng)求、例如制作精靈圖
2县恕、html和CSS放在頁(yè)面上部东羹,javascript放在頁(yè)面下面,因?yàn)閖s加載比HTML和Css加載慢弱睦,所以要優(yōu)先加載html和css,以防頁(yè)面顯示不全百姓,性能差,也影響用戶體驗(yàn)差
后端優(yōu)化:
1况木、緩存存儲(chǔ)讀寫次數(shù)高垒拢,變化少的數(shù)據(jù),比如網(wǎng)站首頁(yè)的信息火惊、商品的信息等求类。應(yīng)用程序讀取數(shù)據(jù)時(shí),一般是先從緩存中讀取屹耐,如果讀取不到或數(shù)據(jù)已失效尸疆,再訪問(wèn)磁盤數(shù)據(jù)庫(kù),并將數(shù)據(jù)再次寫入緩存。
2寿弱、異步方式犯眠,如果有耗時(shí)操作,可以采用異步症革,比如celery
3筐咧、代碼優(yōu)化,避免循環(huán)和判斷次數(shù)太多噪矛,如果多個(gè)if else判斷量蕊,優(yōu)先判斷最有可能先發(fā)生的情況
數(shù)據(jù)庫(kù)優(yōu)化:
1、如有條件艇挨,數(shù)據(jù)可以存放于redis残炮,讀取速度快
2、建立索引缩滨、外鍵等
58势就、使用pop和del刪除字典中的"name"字段,****dic={"name":"zs","age":18}
59楷怒、列出常見(jiàn)MYSQL數(shù)據(jù)存儲(chǔ)引擎
InnoDB:支持事務(wù)處理蛋勺,支持外鍵,支持崩潰修復(fù)能力和并發(fā)控制鸠删。如果需要對(duì)事務(wù)的完整性要求比較高(比如銀行)抱完,要求實(shí)現(xiàn)并發(fā)控制(比如售票),那選擇InnoDB有很大的優(yōu)勢(shì)刃泡。如果需要頻繁的更新巧娱、刪除操作的數(shù)據(jù)庫(kù),也可以選擇InnoDB烘贴,因?yàn)橹С质聞?wù)的提交(commit)和回滾(rollback)禁添。
MyISAM:插入數(shù)據(jù)快,空間和內(nèi)存使用比較低桨踪。如果表主要是用于插入新記錄和讀出記錄老翘,那么選擇MyISAM能實(shí)現(xiàn)處理高效率。如果應(yīng)用的完整性锻离、并發(fā)性要求比 較低铺峭,也可以使用。
MEMORY:所有的數(shù)據(jù)都在內(nèi)存中汽纠,數(shù)據(jù)的處理速度快卫键,但是安全性不高。如果需要很快的讀寫速度虱朵,對(duì)數(shù)據(jù)的安全性要求較低莉炉,可以選擇MEMOEY钓账。它對(duì)表的大小有要求,不能建立太大的表絮宁。所以梆暮,這類數(shù)據(jù)庫(kù)只使用在相對(duì)較小的數(shù)據(jù)庫(kù)表。
60羞福、計(jì)算代碼運(yùn)行結(jié)果惕蹄,zip函數(shù)歷史文章已經(jīng)說(shuō)了,得出[("a",1),("b",2)治专,("c",3),("d",4),("e",5)]
dict()創(chuàng)建字典新方法
61、簡(jiǎn)述同源策略
同源策略需要同時(shí)滿足以下三點(diǎn)要求:
1)協(xié)議相同
2)域名相同
3)端口相同
http:www.test.com與https:www.test.com 不同源——協(xié)議不同
http:www.test.com與http:www.admin.com 不同源——域名不同
http:www.test.com與http:www.test.com:8081 不同源——端口不同
只要不滿足其中任意一個(gè)要求遭顶,就不符合同源策略张峰,就會(huì)出現(xiàn)“跨域”
62、簡(jiǎn)述cookie和session的區(qū)別
1棒旗,session 在服務(wù)器端喘批,cookie 在客戶端(瀏覽器)
2、session 的運(yùn)行依賴 session id铣揉,而 session id 是存在 cookie 中的饶深,也就是說(shuō),如果瀏覽器禁用了 cookie 逛拱,同時(shí) session 也會(huì)失效敌厘,存儲(chǔ)Session時(shí),鍵與Cookie中的sessionid相同朽合,值是開(kāi)發(fā)人員設(shè)置的鍵值對(duì)信息俱两,進(jìn)行了base64編碼,過(guò)期時(shí)間由開(kāi)發(fā)人員設(shè)置
3曹步、cookie安全性比session差
63宪彩、簡(jiǎn)述多線程、多進(jìn)程
進(jìn)程:
1讲婚、操作系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位尿孔,多個(gè)進(jìn)程之間相互獨(dú)立
2、穩(wěn)定性好筹麸,如果一個(gè)進(jìn)程崩潰活合,不影響其他進(jìn)程,但是進(jìn)程消耗資源大竹捉,開(kāi)啟的進(jìn)程數(shù)量有限制
線程:
1芜辕、CPU進(jìn)行資源分配和調(diào)度的基本單位,線程是進(jìn)程的一部分块差,是比進(jìn)程更小的能獨(dú)立運(yùn)行的基本單位侵续,一個(gè)進(jìn)程下的多個(gè)線程可以共享該進(jìn)程的所有資源
2倔丈、如果IO操作密集,則可以多線程運(yùn)行效率高状蜗,缺點(diǎn)是如果一個(gè)線程崩潰需五,都會(huì)造成進(jìn)程的崩潰
應(yīng)用:
IO密集的用多線程,在用戶輸入轧坎,sleep 時(shí)候宏邮,可以切換到其他線程執(zhí)行,減少等待的時(shí)間
CPU密集的用多進(jìn)程缸血,因?yàn)榧偃鏘O操作少蜜氨,用多線程的話,因?yàn)榫€程共享一個(gè)全局解釋器鎖捎泻,當(dāng)前運(yùn)行的線程會(huì)霸占GIL飒炎,其他線程沒(méi)有GIL,就不能充分利用多核CPU的優(yōu)勢(shì)
64笆豁、簡(jiǎn)述any()和all()方法
any():只要迭代器中有一個(gè)元素為真就為真
all():迭代器中所有的判斷項(xiàng)返回都是真郎汪,結(jié)果才為真
python中什么元素為假?
答案:(0闯狱,空字符串煞赢,空列表、空字典哄孤、空元組照筑、None, False)
測(cè)試all()和any()方法
65、IOError录豺、AttributeError朦肘、ImportError、IndentationError双饥、IndexError媒抠、KeyError、SyntaxError咏花、NameError分別代表什么異常
IOError:輸入輸出異常
AttributeError:試圖訪問(wèn)一個(gè)對(duì)象沒(méi)有的屬性
ImportError:無(wú)法引入模塊或包趴生,基本是路徑問(wèn)題
IndentationError:語(yǔ)法錯(cuò)誤,代碼沒(méi)有正確的對(duì)齊
IndexError:下標(biāo)索引超出序列邊界
KeyError:試圖訪問(wèn)你字典里不存在的鍵
SyntaxError:Python代碼邏輯語(yǔ)法出錯(cuò)昏翰,不能執(zhí)行
NameError:使用一個(gè)還未賦予對(duì)象的變量
66苍匆、python中copy和deepcopy區(qū)別
1、復(fù)制不可變數(shù)據(jù)類型棚菊,不管copy還是deepcopy,都是同一個(gè)地址當(dāng)淺復(fù)制的值是不可變對(duì)象(數(shù)值浸踩,字符串,元組)時(shí)和=“賦值”的情況一樣统求,對(duì)象的id值與淺復(fù)制原來(lái)的值相同检碗。
2据块、復(fù)制的值是可變對(duì)象(列表和字典)
淺拷貝copy有兩種情況:
第一種情況:復(fù)制的 對(duì)象中無(wú) 復(fù)雜 子對(duì)象,原來(lái)值的改變并不會(huì)影響淺復(fù)制的值折剃,同時(shí)淺復(fù)制的值改變也并不會(huì)影響原來(lái)的值另假。原來(lái)值的id值與淺復(fù)制原來(lái)的值不同。
第二種情況:復(fù)制的對(duì)象中有 復(fù)雜 子對(duì)象 (例如列表中的一個(gè)子元素是一個(gè)列表)怕犁, 改變?cè)瓉?lái)的值 中的復(fù)雜子對(duì)象的值 边篮,會(huì)影響淺復(fù)制的值。
深拷貝deepcopy:完全復(fù)制獨(dú)立奏甫,包括內(nèi)層列表和字典
67戈轿、列出幾種魔法方法并簡(jiǎn)要介紹用途
init:對(duì)象初始化方法
new:創(chuàng)建對(duì)象時(shí)候執(zhí)行的方法,單列模式會(huì)用到
str:當(dāng)使用print輸出對(duì)象的時(shí)候扶檐,只要自己定義了str(self)方法凶杖,那么就會(huì)打印從在這個(gè)方法中return的數(shù)據(jù)
del:刪除對(duì)象執(zhí)行的方法
68、C:\Users\ry-wu.junya\Desktop>python 1.py 22 33命令行啟動(dòng)程序并傳參款筑,print(sys.argv)會(huì)輸出什么數(shù)據(jù)?
文件名和參數(shù)構(gòu)成的列表
69腾么、請(qǐng)將[i for i in range(3)]改成生成器
生成器是特殊的迭代器奈梳,
1、列表表達(dá)式的【】改為()即可變成生成器
2解虱、函數(shù)在返回值得時(shí)候出現(xiàn)yield就變成生成器攘须,而不是函數(shù)了;
中括號(hào)換成小括號(hào)即可殴泰,有沒(méi)有驚呆了**
70于宙、****a = " hehheh ",去除收尾空格
71、舉例sort和sorted對(duì)列表排序悍汛,list=[0,-1,3,-10,5,9]
72捞魁、對(duì)list排序foo = [-5,8,0,4,9,-4,-20,-2,8,2,-4],使用lambda函數(shù)從小到大排序
73、使用lambda函數(shù)對(duì)list排序foo = [-5,8,0,4,9,-4,-20,-2,8,2,-4]离咐,輸出結(jié)果為
[0,2,4,8,8,9,-2,-4,-4,-5,-20]谱俭,正數(shù)從小到大,負(fù)數(shù)從大到小
(傳兩個(gè)條件宵蛀,x<0和abs(x))
74昆著、列表嵌套字典的排序,分別根據(jù)年齡和姓名排序
foo = [{"name":"zs","age":19},{"name":"ll","age":54},
{"name":"wa","age":17},{"name":"df","age":23}]
75术陶、列表嵌套元組凑懂,分別按字母和數(shù)字排序
76、列表嵌套列表排序梧宫,年齡數(shù)字相同怎么辦接谨?
77摆碉、根據(jù)鍵對(duì)字典排序(方法一,zip函數(shù))
78疤坝、根據(jù)鍵對(duì)字典排序(方法二,不用zip)
有沒(méi)有發(fā)現(xiàn)dic.items和zip(dic.keys(),dic.values())都是為了構(gòu)造列表嵌套字典的結(jié)構(gòu)兆解,方便后面用sorted()構(gòu)造排序規(guī)則
79、列表推導(dǎo)式跑揉、字典推導(dǎo)式锅睛、生成器
80、最后出一道檢驗(yàn)題目历谍,根據(jù)字符串長(zhǎng)度排序现拒,看排序是否靈活運(yùn)用
81、舉例說(shuō)明SQL注入和解決辦法
當(dāng)以字符串格式化書寫方式的時(shí)候望侈,如果用戶輸入的有;+SQL語(yǔ)句印蔬,后面的SQL語(yǔ)句會(huì)執(zhí)行,比如例子中的SQL注入會(huì)刪除數(shù)據(jù)庫(kù)demo
解決方式:通過(guò)傳參數(shù)方式解決SQL注入
**82脱衙、s="******info:xiaoZhang 33 shandong",用正則切分字符串輸出['info', 'xiaoZhang', '33', 'shandong']****
|表示或侥猬,根據(jù)冒號(hào)或者空格切分
83、正則匹配以163.com結(jié)尾的郵箱
84捐韩、遞歸求和
85退唠、python字典和json字符串相互轉(zhuǎn)化方法
json.dumps()字典轉(zhuǎn)json字符串,json.loads()json轉(zhuǎn)字典
86荤胁、MyISAM 與 InnoDB 區(qū)別:
1瞧预、InnoDB 支持事務(wù),MyISAM 不支持仅政,這一點(diǎn)是非常之重要垢油。事務(wù)是一種高
級(jí)的處理方式,如在一些列增刪改中只要哪個(gè)出錯(cuò)還可以回滾還原圆丹,而 MyISAM
就不可以了滩愁;
2、MyISAM 適合查詢以及插入為主的應(yīng)用运褪,InnoDB 適合頻繁修改以及涉及到
安全性較高的應(yīng)用惊楼;
3、InnoDB 支持外鍵秸讹,MyISAM 不支持檀咙;
4、對(duì)于自增長(zhǎng)的字段璃诀,InnoDB 中必須包含只有該字段的索引弧可,但是在 MyISAM
表中可以和其他字段一起建立聯(lián)合索引;
5劣欢、清空整個(gè)表時(shí)棕诵,InnoDB 是一行一行的刪除裁良,效率非常慢。MyISAM 則會(huì)重
建表校套;
87价脾、統(tǒng)計(jì)字符串中某字符出現(xiàn)次數(shù)
88、字符串轉(zhuǎn)化大小寫
89笛匙、用兩種方法去空格
90侨把、正則匹配不是以4和7結(jié)尾的手機(jī)號(hào)
91、簡(jiǎn)述python引用計(jì)數(shù)機(jī)制
python垃圾回收主要以引用計(jì)數(shù)為主妹孙,標(biāo)記-清除和分代清除為輔的機(jī)制秋柄,其中標(biāo)記-清除和分代回收主要是為了處理循環(huán)引用的難題。
引用計(jì)數(shù)算法
當(dāng)有1個(gè)變量保存了對(duì)象的引用時(shí)蠢正,此對(duì)象的引用計(jì)數(shù)就會(huì)加1
當(dāng)使用del刪除變量指向的對(duì)象時(shí)骇笔,如果對(duì)象的引用計(jì)數(shù)不為1,比如3嚣崭,那么此時(shí)只會(huì)讓這個(gè)引用計(jì)數(shù)減1笨触,即變?yōu)?,當(dāng)再次調(diào)用del時(shí)雹舀,變?yōu)?旭旭,如果再調(diào)用1次del,此時(shí)會(huì)真的把對(duì)象進(jìn)行刪除
92葱跋、int("1.4"),int(1.4)輸出結(jié)果?
int("1.4")報(bào)錯(cuò)源梭,int(1.4)輸出1
93娱俺、列舉3條以上PEP8編碼規(guī)范
1、頂級(jí)定義之間空兩行废麻,比如函數(shù)或者類定義荠卷。
2、方法定義烛愧、類定義與第一個(gè)方法之間油宜,都應(yīng)該空一行
3、三引號(hào)進(jìn)行注釋
4怜姿、使用Pycharm慎冤、Eclipse一般使用4個(gè)空格來(lái)縮進(jìn)代碼
94、正則表達(dá)式匹配第一個(gè)URL
findall結(jié)果無(wú)需加group(),search需要加group()提取
95沧卢、正則匹配中文
96蚁堤、簡(jiǎn)述樂(lè)觀鎖和悲觀鎖
悲觀鎖, 就是很悲觀,每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人會(huì)修改但狭,所以每次在拿數(shù)據(jù)的時(shí)候都會(huì)上鎖披诗,這樣別人想拿這個(gè)數(shù)據(jù)就會(huì)block直到它拿到鎖撬即。傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)里邊就用到了很多這種鎖機(jī)制,比如行鎖呈队,表鎖等剥槐,讀鎖,寫鎖等宪摧,都是在做操作之前先上鎖粒竖。
樂(lè)觀鎖,就是很樂(lè)觀绍刮,每次去拿數(shù)據(jù)的時(shí)候都認(rèn)為別人不會(huì)修改,所以不會(huì)上鎖孩革,但是在更新的時(shí)候會(huì)判斷一下在此期間別人有沒(méi)有去更新這個(gè)數(shù)據(jù)岁歉,可以使用版本號(hào)等機(jī)制,樂(lè)觀鎖適用于多讀的應(yīng)用類型膝蜈,這樣可以提高吞吐量
97锅移、r、r+饱搏、rb非剃、rb+文件打開(kāi)模式區(qū)別
模式較多,比較下背背記記即可
98推沸、Linux命令重定向 > 和 >>
Linux 允許將命令執(zhí)行結(jié)果 重定向到一個(gè) 文件
將本應(yīng)顯示在終端上的內(nèi)容 輸出/追加 到指定文件中
表示輸出备绽,會(huì)覆蓋文件原有的內(nèi)容
表示追加,會(huì)將內(nèi)容追加到已有文件的末尾
用法示例:
<pre style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: 0.544px; orphans: 2; text-align: justify; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); color: rgb(62, 62, 62); font-size: 16px;">將 echo 輸出的信息保存到 1.txt 里echo Hello Python > 1.txt
將 tree 輸出的信息追加到 1.txt 文件的末尾tree >> 1.txt</pre>
99鬓催、正則表達(dá)式匹配出<html><h1>www.itcast.cn</h1></html>
前面的<>和后面的<>是對(duì)應(yīng)的肺素,可以用此方法
100、python傳參數(shù)是傳值還是傳址宇驾?
Python中函數(shù)參數(shù)是引用傳遞(注意不是值傳遞)倍靡。對(duì)于不可變類型(數(shù)值型、字符串课舍、元組)塌西,因變量不能修改,所以運(yùn)算不會(huì)影響到變量自身筝尾;而對(duì)于可變類型(列表字典)來(lái)說(shuō)捡需,函數(shù)體運(yùn)算可能會(huì)更改傳入的參數(shù)變量。
101忿等、求兩個(gè)列表的交集栖忠、差集、并集
102、生成0-100的隨機(jī)數(shù)
random.random()生成0-1之間的隨機(jī)小數(shù)庵寞,所以乘以100
103狸相、lambda匿名函數(shù)好處
精簡(jiǎn)代碼,lambda省去了定義函數(shù)捐川,map省去了寫for循環(huán)過(guò)程
104脓鹃、常見(jiàn)的網(wǎng)絡(luò)傳輸協(xié)議
UDP、TCP古沥、FTP瘸右、HTTP、SMTP等等
105岩齿、單引號(hào)太颤、雙引號(hào)、三引號(hào)用法
1盹沈、單引號(hào)和雙引號(hào)沒(méi)有什么區(qū)別龄章,不過(guò)單引號(hào)不用按shift,打字稍微快一點(diǎn)乞封。表示字符串的時(shí)候做裙,單引號(hào)里面可以用雙引號(hào),而不用轉(zhuǎn)義字符,反之亦然肃晚。
'She said:"Yes." '
or
"She said: 'Yes.' "
2锚贱、但是如果直接用單引號(hào)擴(kuò)住單引號(hào),則需要轉(zhuǎn)義关串,像這樣:
' She said:\'Yes.\' '
3拧廊、三引號(hào)可以直接書寫多行,通常用于大段晋修,大篇幅的字符串
"""
hello
world
"""
106卦绣、python垃圾回收機(jī)制
python垃圾回收主要以引用計(jì)數(shù)為主,標(biāo)記-清除和分代清除為輔的機(jī)制飞蚓,其中標(biāo)記-清除和分代回收主要是為了處理循環(huán)引用的難題。
引用計(jì)數(shù)算法
當(dāng)有1個(gè)變量保存了對(duì)象的引用時(shí)廊蜒,此對(duì)象的引用計(jì)數(shù)就會(huì)加1
當(dāng)使用del刪除變量指向的對(duì)象時(shí)趴拧,如果對(duì)象的引用計(jì)數(shù)不為1仁锯,比如3捞蛋,那么此時(shí)只會(huì)讓這個(gè)引用計(jì)數(shù)減1,即變?yōu)?憎乙,當(dāng)再次調(diào)用del時(shí)屁倔,變?yōu)?脑又,如果再調(diào)用1次del,此時(shí)會(huì)真的把對(duì)象進(jìn)行刪除
107、HTTP請(qǐng)求中g(shù)et和post區(qū)別
1问麸、GET請(qǐng)求是通過(guò)URL直接請(qǐng)求數(shù)據(jù)往衷,數(shù)據(jù)信息可以在URL中直接看到,比如瀏覽器訪問(wèn)严卖;而POST請(qǐng)求是放在請(qǐng)求頭中的席舍,我們是無(wú)法直接看到的;
2哮笆、GET提交有數(shù)據(jù)大小的限制来颤,一般是不超過(guò)1024個(gè)字節(jié),而這種說(shuō)法也不完全準(zhǔn)確稠肘,HTTP協(xié)議并沒(méi)有設(shè)定URL字節(jié)長(zhǎng)度的上限福铅,而是瀏覽器做了些處理,所以長(zhǎng)度依據(jù)瀏覽器的不同有所不同项阴;POST請(qǐng)求在HTTP協(xié)議中也沒(méi)有做說(shuō)明滑黔,一般來(lái)說(shuō)是沒(méi)有設(shè)置限制的,但是實(shí)際上瀏覽器也有默認(rèn)值鲁冯】椒校總體來(lái)說(shuō),少量的數(shù)據(jù)使用GET薯演,大量的數(shù)據(jù)使用POST撞芍。
3、GET請(qǐng)求因?yàn)閿?shù)據(jù)參數(shù)是暴露在URL中的跨扮,所以安全性比較低序无,比如密碼是不能暴露的,就不能使用GET請(qǐng)求衡创;POST請(qǐng)求中帝嗡,請(qǐng)求參數(shù)信息是放在請(qǐng)求頭的,所以安全性較高璃氢,可以使用哟玷。在實(shí)際中,涉及到登錄操作的時(shí)候一也,盡量使用HTTPS請(qǐng)求巢寡,安全性更好。
108椰苟、python中讀取Excel文件的方法
應(yīng)用數(shù)據(jù)分析庫(kù)pandas
109抑月、簡(jiǎn)述多線程、多進(jìn)程
進(jìn)程:
1舆蝴、操作系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位谦絮,多個(gè)進(jìn)程之間相互獨(dú)立
2题诵、穩(wěn)定性好,如果一個(gè)進(jìn)程崩潰层皱,不影響其他進(jìn)程性锭,但是進(jìn)程消耗資源大,開(kāi)啟的進(jìn)程數(shù)量有限制
線程:
1奶甘、CPU進(jìn)行資源分配和調(diào)度的基本單位篷店,線程是進(jìn)程的一部分,是比進(jìn)程更小的能獨(dú)立運(yùn)行的基本單位臭家,一個(gè)進(jìn)程下的多個(gè)線程可以共享該進(jìn)程的所有資源
2疲陕、如果IO操作密集,則可以多線程運(yùn)行效率高钉赁,缺點(diǎn)是如果一個(gè)線程崩潰蹄殃,都會(huì)造成進(jìn)程的崩潰
應(yīng)用:
IO密集的用多線程,在用戶輸入你踩,sleep 時(shí)候诅岩,可以切換到其他線程執(zhí)行,減少等待的時(shí)間
CPU密集的用多進(jìn)程带膜,因?yàn)榧偃鏘O操作少吩谦,用多線程的話,因?yàn)榫€程共享一個(gè)全局解釋器鎖膝藕,當(dāng)前運(yùn)行的線程會(huì)霸占GIL式廷,其他線程沒(méi)有GIL,就不能充分利用多核CPU的優(yōu)勢(shì)
110芭挽、python正則中search和match