一、函数的嵌套调用
二、变量的作用域
- 为了避免变量的名称发生冲突,所以Python引入了命名空间的概念。
- 命名空间指的是名称到对象的映射,类似于字典,键名是变量的名字,值是变量的值。
- 命名空间是相互独立存在的,而且它们被安排在某个特定的层次,把这些层次结构组合起来就是作用域。
本地作用域 函数嵌套作用域 文件作用域 内置作用域
局部变量
- 所谓局部变量,就是在函数内部定义的变量。
- 局部变量的作用域是函数内部,意味着它只在定义它的函数中有效,一旦函数结束就会消失。
全局变量
- 定义在函数外的拥有全局作用域。
- 全局变量可以在整个程序范围内访问。
- 如果出现全局变量和局部变量名字相同的情况,则在函数中访问的是局部变量。
三、递归函数和匿名函数
递归函数
一个函数的内部可以调用其他函数。但是,如果一个函数在内部不调用其它的函数,而是自己本身的话,这个函数就是递归函数。
使用递归,实现阶乘 n! = 1 * 2 * 3 * … * n的计算。
匿名函数
匿名函数就是没有名称的函数,也就是不再使用def语句定义的函数。如果要声明匿名函数,则需要使用lambda关键字,匿名函数的声明格式如下所示:
lambda [arg1 [,arg2,.....argn]]:expression
匿名函数示例代码:
sum = lambda arg1, arg2: arg1 + arg2
print(“运行结果:", sum( 10, 20 ))
print("运行结果:", sum( 20, 20 ))
运行结果:
运行结果: 30
运行结果: 40
注意:使用Lambda声明的匿名函数能接收任何数量的参数,但只能返回一个表达式的值。匿名函数不能直接调用print,因为lambda需要一个表达式。
四、日期时间函数
1、时间函数
在Python中,通常有如下几种方式表示时间:
(1)时间戳;
(2)格式化的时间字符串;
(3)时间元组(struct_time)。
通常来讲,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。
import time; # 引入time模块
ticks = time.time()
print("当前时间戳为:", ticks)
运行结果:
当前时间戳为: 1550135979.829278
2、格式化的时间字符串
import time
# 格式化成2016-03-20 11:45:39形式
print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))
运行结果:
2019-02-14 17:20:57
3、格式化的时间字符串
4、时间元组
返回struct_time的函数主要有gmtime()、localtime()和strptime(),struct_time元组。
序号 | 字段 | 值 |
---|---|---|
0 | tm_year | 2008 |
1 | tm_mon | 1到12 |
2 | tm_mday | 1到31 |
3 | t_hour | 0到23 |
4 | tm_min | 0到59 |
5 | tm_sec | 0到61 |
6 | tm_ wday | 0到6 |
7 | tm_yday | 1到366 |
8 | tm_isdst | -1,0,1,-1是决定是否为夏令时的旗帜 |
-
time.altzone
返回格林威治西部的夏令时地区的偏移秒数。如果该地区在格林威治东部会返回负值(如西欧,包括英国)。对夏令时启用地区才能使用。 -
time.asctime([tupletime])
接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2008"(2008年12月11日 周二18时07分14秒)的24个字符的字符串。 -
time.asctime([tupletime])
接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2008"(2008年12月11日 周二18时07分14秒)的24个字符的字符串。 -
time.clock( )
用以浮点数计算的秒数返回当前的CPU时间。用来衡量不同程序的耗时,比time.time()更有用。 -
time.ctime([secs])
作用相当于asctime(localtime(secs)),未给参数相当于asctime()。 -
time.gmtime([secs])
接收时间辍(1970纪元后经过的浮点秒数)并返回格林威治天文时间下的时间元组t。 -
time.localtime([secs])
接收时间辍(1970纪元后经过的浮点秒数)并返回当地时间下的时间元组t(t.tm_isdst可取0或1,取决于当地当时是不是夏令时) -
time.localtime([secs])
接收时间辍(1970纪元后经过的浮点秒数)并返回当地时间下的时间元组t -
time.mktime(tupletime)
接受时间元组并返回时间辍 -
time.sleep(secs)
推迟调用线程的运行,secs指秒数。 -
time.strftime(fmt[,tupletime])
接收以时间元组,并返回以可读字符串表示的当地时间,格式由fmt决定。 -
time.strptime(str,fmt='%a %b %d %H:%M:%S %Y')
根据fmt的格式把一个时间字符串解析为时间元组。 -
time.time( )
返回当前时间的时间戳 -
time.tzset()
根据环境变量TZ重新初始化时间相关设置。 -
time.tzname
包含一对根据情况的不同而不同的字符串,分别是带夏令时的本地时区名称,和不带的。
5、日历函数 -
calendar.calendar(year,w=2,l=1,c=6)
返回一个多行字符串格式的year年年历,3个月一行,间隔距离为c。每日宽度间隔为w字符。每行长度为21* W+18+2* C。l是每星期行数。 -
calendar. firstweekday()
返回当前每周起始日期的设置。默认情况下,首次载入caendar模块时返回0,即星期一。 -
calendar.isleap(year)
如果是闰年返回True,否则为false。 -
calendar.leapdays(y1,y2)
返回在Y1,Y2两年之间的闰年总数。 -
calendar.month(year,month,w=2,l=1)
返回一个多行字符串格式的year年month月日历,两行标题,一周一行。每日宽度间隔为w字符。每行的长度为7* w+6。l是每星期的行数。 -
calendar.monthcalendar(year,month)
返回一个整数的单层嵌套列表。每个子列表装载代表一个星期的整数。Year年month月外的日期都设为0;范围内的日子都由该月第几日表示,从1开始。 -
calendar.monthrange(year,month)
返回两个整数。第一个是该月的星期几的日期码,第二个是该月的日期码。日从0(星期一)到6(星期日);月从1到12。 -
calendar.prcal(year,w=2,l=1,c=6)
相当于print(calendar.calendar(year,w,l,c)) -
calendar.setfirstweekday(weekday)
设置每周的起始日期码。0(星期一)到6(星期日) -
calendar.prmonth(year,month,w=2,l=1)
相当于 print(calendar.calendar(year,w,l,c)) -
calendar.timegm(tupletime)
和time.gmtime相反:接受一个时间元组形式,返回该时刻的时间辍(1970纪元后经过的浮点秒数) -
calendar.weekday(year,month,day)
返回给定日期的日期码。0(星期一)到6(星期日)。月份为 1(一月) 到 12(12月)。
五、随机数函数
1、随机数函数
random.random()
用于生成一个0到1的随机符点数: 0 <= n < 1.0。
import random
# 生成第一个随机数
print("random():", random.random())
# 生成第二个随机数
print("random():", random.random())
运行结果:
random(): 0.2763957830786208
random(): 0.7992142244936699
random.uniform(a,b)
返回a,b之间的随机浮点数,范围[a,b]或[a,b]取决于四舍五入,a不一定要比b小。
import random
print("random:",random.uniform(50,100))
print("random:",random.uniform(100,50))
运行结果:
random: 68.42964714500464
random: 56.53172829853103
random.randint(a,b)
返回a,b之间的整数,范围[a,b],注意:传入参数必须是整数,a一定要比b小。
import random
#生成的随机数n: 12 <= n <= 20
print(random.randint(12,20))
运行结果:
16
random.randrang([start], stop[, step])
返回有个区间内的整数,可以设置step。只能传入整数,random.randrange(10, 100, 2),结果相当于从[10, 12, 14, 16, … 96, 98]序列中获取一个随机数。
import random
print(random.randrange(10,100,2) )
运行结果:
38
random.choice(sequence)
从sequence(序列,是有序类型的)中随机获取一个元素,列表、元组、字符串都属于sequence。
import random
print(random.randrange(10,100,2) )
#结果等效于:
print(random.choice(range(10,100,2) )
运行结果:
66
random.shuffle(x[,random])
用于将列表中的元素打乱顺序,俗称为洗牌。
p = ["Python","is", "powerful","simple”]
random.shuffle(p)
random.sample(sequence,k)
从指定序列中随机获取k个元素作为一个片段返回,
sample函数不会修改原有序列
list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
slice = random.sample(list, 5)
print(slice)
print(list)
运行结果:
[4, 2, 6, 9, 10]
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]