gpt4 book ai didi

python 中的列表生成式、生成器表达式、模块导入

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 29 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章python 中的列表生成式、生成器表达式、模块导入由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

5.16 列表生成式 。

?
1
2
3
4
5
6
7
8
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 列表生成式与生成器表达式的应用 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
names = [ 'egon' , 'alex_sb' , 'wupeiqi' , 'yuanhao' , 'lxx' ]
res = map ( lambda x:x.upper(),names)  # map函数 映射
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 = []                 #一般循环方法
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)  #去掉括号

第六章模块 。

什么是模块? 模块就是一系统功能的集合体,在python中,一个py文件就是一个模块,比如module.py,其中模块名module 。

6.1 import 导入模块 。

6.11 导入方式一 。

?
1
2
import spam
spam.read1()

首次导入模块发生三件事 ​ 1、创建一个模块的名称空间 ​ 2、执行模块对应文件,将产生的名字存放于1中的名称空间 ​ 3、在当前执行文件中拿到一个模块名,该模块名指向1的名称空间 。

?
1
2
3
4
5
6
7
8
9
import spam
强调:之后的导入会直接引用第一次导入的结果,不会重复执行文件
import spam
print (spam)
模块中功能的执行始终以模块自己的名称空间为准
read1 = 111111    #money=1000
spam.read1()    #def read1():
           #  print('spam模块.read1:',money)
#结果:spam模块.read1: 1000

为模块起别名

?
1
2
3
4
5
6
7
8
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 导入方式二 。

?
1
2
3
4
from spam import money,read1,read2,change
read1()​
from spam import *   #从模块中导入所有方法
read1()        #spam中:__all__=['money','read1'] 表示*能导入的方法,不写则表示能导入所有​

首次导入模块发生三件事 1、创建一个模块的名称空间 2、执行模块对应文件,将产生的名字存放于1中的名称空间 提示:from...... import....... 与import前两件事一模一样 3、在当前名称空间中直接拿到模块中的名字,可以直接使用,不用加任何前缀同import,执行模块中的功能,始终以模块的名称空间为准 。

?
1
2
3
4
5
6
7
from spam import read1
money = 1111111111
read1()   #结果:spam模块.read1: 1000
from ... import ......名字,拿到的名字可以不加前缀直接使用,使用起来更加方便, 但问题是容易与当前执行文件中相同的名字冲突
from spam import money
money = 1111111111111111
print (money)    #1111111111111111,而不是1000

为模块起别名

?
1
2
from spam import money as m
print (m)

在一行导入多个 。

from spam import money,read1,read2 。

6.2 文件的两种执行方式:

?
1
2
3
4
5
6
7
8
9
10
11
#print(__name__)
__name__的值:
1 、在文件被直接执行的情况下,等于 '__main__'
2 、在文件被导入的情况下,等于模块名
if __name__ = = '__main__' :
    print ( '文件被当中脚本执行啦。、。' )
   read1()
else :
    print ( '文件被导入啦' )
    read2()

6.3 模块的搜索路径 。

模块的查找顺序是:

内存中已经加载的模块 -----》内置模块-------》sys.path路径中包含的模块 。

?
1
2
3
4
5
import sys
sys.path.append(r 'd:codesh_fullstack_s1day14dir1' )
import m1
m1.f1()

强调 : sys.path的第一个路径是当前执行文件所在的文件夹 。

总结 。

以上所述是小编给大家介绍的python 中的列表生成式、生成器表达式、模块导入,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢! 原文链接:https://www.cnblogs.com/mylu/archive/2019/06/18/11048080.html 。

最后此篇关于python 中的列表生成式、生成器表达式、模块导入的文章就讲到这里了,如果你想了解更多关于python 中的列表生成式、生成器表达式、模块导入的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com