python 中的列表生成式、生成器表達(dá)式、模塊導(dǎo)入
5.16 列表生成式
l=[] for i in range(100): l.append('egg%s' %i) print(l) l=['egg%s' %i for i in range(100)] l=['egg%s' %i for i in range(1000) if i > 10] print(l)
5.17 列表生成式與生成器表達(dá)式的應(yīng)用
names=['egon','alex_sb','wupeiqi','yuanhao','lxx'] res=map(lambda x:x.upper(),names) # map函數(shù) 映射 names=list(res) #['EGON', 'ALEX_SB', 'WUPEIQI', 'YUANHAO', 'LXX'] print(names) names=['egon','alex_sb','wupeiqi','yuanhao','lxx'] names=[name.upper() for name in names] #列表生成式 print(names) names=['egon','alex_sb','wupeiqi','yuanhao','lxx'] #列表生成式 names=[len(name) for name in names if not name.endswith('sb')] print(names) nums=[] #一般循環(huán)方法 with open('a.txt','r',encoding='utf-8') as f: for line in f: nums.append(len(line)) print(max(nums)) with open('a.txt','r',encoding='utf-8') as f:#列表生成式 nums=[len(line) for line in f] print(max(nums)) #28 with open('a.txt','r',encoding='utf-8') as f: nums=(len(line) for line in f) #生成器表達(dá)式 print(next(nums)) #15 print(next(nums)) #17 print(next(nums)) #13 print(max(nums)) #28 print(max(nums)) #空列表 max(len(line) for line in f) #去掉括號(hào)
第六章模塊
什么是模塊? 模塊就是一系統(tǒng)功能的集合體,在python中,一個(gè)py文件就是一個(gè)模塊,比如module.py,其中模塊名module
6.1 import 導(dǎo)入模塊
6.11 導(dǎo)入方式一
import spam spam.read1()
首次導(dǎo)入模塊發(fā)生三件事 1、創(chuàng)建一個(gè)模塊的名稱空間 2、執(zhí)行模塊對(duì)應(yīng)文件,將產(chǎn)生的名字存放于1中的名稱空間 3、在當(dāng)前執(zhí)行文件中拿到一個(gè)模塊名,該模塊名指向1的名稱空間
import spam 強(qiáng)調(diào):之后的導(dǎo)入會(huì)直接引用第一次導(dǎo)入的結(jié)果,不會(huì)重復(fù)執(zhí)行文件 import spam print(spam) 模塊中功能的執(zhí)行始終以模塊自己的名稱空間為準(zhǔn) read1=111111 #money=1000 spam.read1() #def read1(): # print('spam模塊.read1:',money) #結(jié)果:spam模塊.read1: 1000
為模塊起別名:
import spam as sm sm.read1() engine=input('>>: ').strip() if engine == 'mysql': import mysql as db else engine == 'oracle': import oracle as db db.parse()
一行導(dǎo)入多個(gè)模塊(不推薦使用)
import spam,mysql,oracle
6.12 導(dǎo)入方式二
from spam import money,read1,read2,change read1() from spam import * #從模塊中導(dǎo)入所有方法 read1() #spam中:__all__=['money','read1'] 表示*能導(dǎo)入的方法,不寫則表示能導(dǎo)入所有
首次導(dǎo)入模塊發(fā)生三件事 1、創(chuàng)建一個(gè)模塊的名稱空間 2、執(zhí)行模塊對(duì)應(yīng)文件,將產(chǎn)生的名字存放于1中的名稱空間 提示:from...... import....... 與import前兩件事一模一樣 3、在當(dāng)前名稱空間中直接拿到模塊中的名字,可以直接使用,不用加任何前綴同import,執(zhí)行模塊中的功能,始終以模塊的名稱空間為準(zhǔn)
from spam import read1 money=1111111111 read1() #結(jié)果:spam模塊.read1: 1000 from ... import ......名字,拿到的名字可以不加前綴直接使用,使用起來更加方便, 但問題是容易與當(dāng)前執(zhí)行文件中相同的名字沖突 from spam import money money=1111111111111111 print(money) #1111111111111111,而不是1000
為模塊起別名:
from spam import money as m print(m)
在一行導(dǎo)入多個(gè)
from spam import money,read1,read2
6.2 文件的兩種執(zhí)行方式:
#print(__name__) __name__的值: 1、在文件被直接執(zhí)行的情況下,等于'__main__' 2、在文件被導(dǎo)入的情況下,等于模塊名 if __name__ == '__main__': print('文件被當(dāng)中腳本執(zhí)行啦。、。') read1() else: print('文件被導(dǎo)入啦') read2()
6.3 模塊的搜索路徑
模塊的查找順序是:
內(nèi)存中已經(jīng)加載的模塊 -----》內(nèi)置模塊-------》sys.path路徑中包含的模塊
import sys sys.path.append(r'D:\code\SH_fullstack_s1\day14\dir1') import m1 m1.f1()
強(qiáng)調(diào) : sys.path的第一個(gè)路徑是當(dāng)前執(zhí)行文件所在的文件夾
總結(jié)
以上所述是小編給大家介紹的python 中的列表生成式、生成器表達(dá)式、模塊導(dǎo)入,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
關(guān)于windos10環(huán)境下編譯python3版pjsua庫的問題
pjsua默認(rèn)綁定的python版本是python 2.4,使用起來有諸多限制,希望可以使用python3調(diào)用pjsua的庫實(shí)現(xiàn)軟電話的基礎(chǔ)功能。這篇文章主要介紹了windos10環(huán)境下編譯python3版pjsua庫,需要的朋友可以參考下2021-10-10python使用Pyinstaller如何打包整個(gè)項(xiàng)目
這篇文章主要介紹了python使用Pyinstaller如何打包整個(gè)項(xiàng)目,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11Python隊(duì)列RabbitMQ 使用方法實(shí)例記錄
這篇文章主要介紹了Python隊(duì)列RabbitMQ 使用方法,結(jié)合實(shí)例形式分析了Python隊(duì)列RabbitMQ創(chuàng)建隊(duì)列發(fā)送消息與創(chuàng)建消費(fèi)者消費(fèi)信息相關(guān)操作技巧,需要的朋友可以參考下2019-08-08Pythony運(yùn)維入門之Socket網(wǎng)絡(luò)編程詳解
這篇文章主要介紹了Pythony運(yùn)維入門之Socket網(wǎng)絡(luò)編程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Python如何根據(jù)頁碼處理PDF文件的內(nèi)容
在Python中,fitz庫可以用于多種任務(wù),如打開PDF文件、遍歷頁面、添加注釋、提取文本、旋轉(zhuǎn)頁面等,此外,它還可以用于在PDF頁面上添加高亮注釋、提取圖像等操作,這篇文章主要介紹了Python根據(jù)頁碼處理PDF文件的內(nèi)容,需要的朋友可以參考下2024-06-06