python 中的列表生成式、生成器表達式、模塊導入
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 列表生成式與生成器表達式的應用
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) #生成器表達式
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) #去掉括號
第六章模塊
什么是模塊? 模塊就是一系統(tǒng)功能的集合體,在python中,一個py文件就是一個模塊,比如module.py,其中模塊名module
6.1 import 導入模塊
6.11 導入方式一
import spam spam.read1()
首次導入模塊發(fā)生三件事 1、創(chuàng)建一個模塊的名稱空間 2、執(zhí)行模塊對應文件,將產生的名字存放于1中的名稱空間 3、在當前執(zhí)行文件中拿到一個模塊名,該模塊名指向1的名稱空間
import spam
強調:之后的導入會直接引用第一次導入的結果,不會重復執(zhí)行文件
import spam
print(spam)
模塊中功能的執(zhí)行始終以模塊自己的名稱空間為準
read1=111111 #money=1000
spam.read1() #def read1():
# print('spam模塊.read1:',money)
#結果: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()
一行導入多個模塊(不推薦使用)
import spam,mysql,oracle
6.12 導入方式二
from spam import money,read1,read2,change read1() from spam import * #從模塊中導入所有方法 read1() #spam中:__all__=['money','read1'] 表示*能導入的方法,不寫則表示能導入所有
首次導入模塊發(fā)生三件事 1、創(chuàng)建一個模塊的名稱空間 2、執(zhí)行模塊對應文件,將產生的名字存放于1中的名稱空間 提示:from...... import....... 與import前兩件事一模一樣 3、在當前名稱空間中直接拿到模塊中的名字,可以直接使用,不用加任何前綴同import,執(zhí)行模塊中的功能,始終以模塊的名稱空間為準
from spam import read1 money=1111111111 read1() #結果:spam模塊.read1: 1000 from ... import ......名字,拿到的名字可以不加前綴直接使用,使用起來更加方便, 但問題是容易與當前執(zhí)行文件中相同的名字沖突 from spam import money money=1111111111111111 print(money) #1111111111111111,而不是1000
為模塊起別名:
from spam import money as m print(m)
在一行導入多個
from spam import money,read1,read2
6.2 文件的兩種執(zhí)行方式:
#print(__name__)
__name__的值:
1、在文件被直接執(zhí)行的情況下,等于'__main__'
2、在文件被導入的情況下,等于模塊名
if __name__ == '__main__':
print('文件被當中腳本執(zhí)行啦。、。')
read1()
else:
print('文件被導入啦')
read2()
6.3 模塊的搜索路徑
模塊的查找順序是:
內存中已經加載的模塊 -----》內置模塊-------》sys.path路徑中包含的模塊
import sys sys.path.append(r'D:\code\SH_fullstack_s1\day14\dir1') import m1 m1.f1()
強調 : sys.path的第一個路徑是當前執(zhí)行文件所在的文件夾
總結
以上所述是小編給大家介紹的python 中的列表生成式、生成器表達式、模塊導入,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
相關文章
使用Python實現(xiàn)在Word中添加或刪除超鏈接
在Word文檔中,超鏈接是一種將文本或圖像連接到其他文檔、網頁或同一文檔中不同部分的功能,本文將為大家介紹一下Python如何實現(xiàn)在Word中添加或刪除超鏈接,需要的可以參考下2025-01-01
pycharm設置當前工作目錄的操作(working directory)
今天小編就為大家分享一篇pycharm設置當前工作目錄的操作(working directory),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
python3.3使用tkinter開發(fā)猜數(shù)字游戲示例
這篇文章主要介紹了python3.3使用tkinter開發(fā)猜數(shù)字游戲示例,需要的朋友可以參考下2014-03-03
python基于json文件實現(xiàn)的gearman任務自動重啟代碼實例
這篇文章主要介紹了python基于json文件實現(xiàn)的gearman任務自動重啟代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08
matplotlib?雙y軸繪制及合并圖例的實現(xiàn)代碼
這篇文章主要介紹了matplotlib?雙y軸繪制及合并圖例,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-10-10

