您的位置:首页 > 编程语言 > Python开发

python全栈开发-常用模块的一些应用

2018-04-08 15:55 363 查看

一、random模块详解

1、概述

  首先我们看到这个单词是随机的意思,他在python中的主要用于一些随机数,或者需要写一些随机数的代码,下面我们就来整理他的一些用法

2、常用方法

1. random.random()

功能:用于生成一个0到1的随机浮点数





2. random.randint(a,b)

功能:随机返回a到b之间任意一个数,也包括a,b



3. random.randrange(start, stop=None, step=1)

功能:随机返回start到stop,但是不包括stop值



4. random.choice(范围)

功能:随机取范围里的一个值,这个范围可以是元组,字符串,列表



5. [b]random.sample(population, k)[/b]

功能:从population中随机获取k个值,以列表的形式返回



6. random.uniform(a,b)

[b]功能:用于生成一个a到b的随机浮点数[/b]



7. random.shuffle()

功能:洗牌,假设参数是一个数字列表,用完后数字的顺序就随机排列





二、string模块详解

常用方法:

1. string.ascii_letters

功能:返回大小写字母的字符串



2. string.ascii_lowercase

功能:返回小写字母的字符串



3. string.ascii_uppercase

功能:返回大写字母的字符串



4. string.digits

功能:返回0-9数字的字符串



5. string.punctuation

功能:返回所有特殊字符,并以字符串形式返回





三、生成随机验证码

1、第一种方法

import random,string
check_code = ''    #空的字符串
for i in range(5):   #生成五位数
  current = random.randrange(0,5)     #随机生成的整数
  if current == i:    #随机生成的数等于i
    txt = random.choice(string.ascii_letters)   #就取随机字母大小写
  else:
    txt = str(random.randint(0,9))
    check_code+=txt
print(check_code)


2、第二种方法

import random
def func(n):
res = ''
for i in range(n):
s1 = chr(random.randint(65, 90))   #asc码的对应数字位置
s2 = str(random.randint(0, 9))
res += random.choice([s1, s2])
return res

print(func(5))  #想要几位数验证码就搞几位


四、进度条

# =========知识储备==========
# 进度条的效果
# [#             ]
# [##            ]
# [###           ]
# [####          ]
#
# 指定宽度
# print('[%-15s]' %"#")  #横杠代表左对齐
# print('[%-15s]' %'##')
# print('[%-15s]' %'###')
# print('[%-15s]' %'####')
#
# #打印%
# print('%s%%' %(40)) #第二个%号代表取消第一个%的特殊意义
#
# #可传参来控制宽度
# print(('[%%-%ds]' %50) %'#')
# print(('[%%-%ds]' %50) %'##')
# print(('[%%-%ds]' %50) %'###')
# =========实现打印进度条函数==========
import time

def progress(percent,width=50):
if percent >= 1:
percent=1
show_str=('[%%-%ds]' %width) %(int(width*percent)*'#')
print('\r%s %d%%' %(show_str,int(100*percent)),end='')   #\r每次在行首打印

#=========应用==========
data_size=1025    #这里是接受的总值
recv_size=0
while recv_size < data_size:
time.sleep(0.2) #模拟数据的传输延迟
recv_size+=100 #每次收1024
percent=recv_size/data_size #接收的比例
progress(percent,width=70) #进度条的宽度70


五、time与datetime

  在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 3)元组(struct_time)共九个元素。由于Python的time模块实现主要调用C库,所以各个平台可能有所不同。

UTC(Coordinated Universal Time,世界协调时)亦即格林威治天文时间,世界标准时间。在中国为UTC+8。DST(Daylight Saving Time)即夏令时。

时间戳(timestamp)的方式:通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。我们运行“type(time.time())”,返回的是float类型。返回时间戳方式的函数主要有time(),clock()等。

元组(struct_time)方式:struct_time元组共有9个元素,返回struct_time的函数主要有gmtime(),localtime(),strptime()。下面列出这种方式元组中的几个元素:

索引(Index)属性(Attribute)值(Values)
0tm_year(年)比如2018
1tm_mon(月)1 - 12
2tm_mday(日)1 - 31
3tm_hour(时)0 - 23
4tm_min(分)0 - 59
5tm_sec(秒)0 - 61
6tm_wday(weekday)0 - 6(0表示周日)
7tm_yday(一年中的第几天)1 - 366
8tm_isdst(是否是夏令时)默认为-1
接着介绍time模块中常用的几个函数:

1)time.localtime([secs]):将一个时间戳转换为当前时区的struct_time。secs参数未提供,则以当前时间为准。

如何取其中的数值呢



2)time.gmtime([secs]):和localtime()方法类似,gmtime()方法是将一个时间戳转换为UTC时区(0时区)(跟中国时区相差8小时)的struct_time。



3)time.time():返回当前时间的时间戳。



4)time.mktime(t):将一个struct_time转化为时间戳。



5)time.sleep(secs):线程推迟指定的时间运行。单位为秒。 #这个就不多说

6)time.clock():这个需要注意,在不同的系统上含义不同。在UNIX系统上,它返回的是“进程时间”,它是用秒表示的浮点数(时间戳)。而在WINDOWS中,第一次调用,返回的是进程运行的实际时间。而第二次之后的调用是自第一次调用以后到现在的运行时间。(实际上是以WIN32上QueryPerformanceCounter()为基础,它比毫秒表示更为精确)

import time
if __name__ == '__main__':
time.sleep(1)
print "clock1:%s" % time.clock()
time.sleep(1)
print "clock2:%s" % time.clock()
time.sleep(1)
print "clock3:%s" % time.clock()
#运行结果:

clock1:3.35238137808e-006
clock2:1.00004944763
clock3:2.00012040636

#其中第一个clock()输出的是程序运行时间

#第二、三个clock()输出的都是与第一个clock的时间间隔


7)time.asctime([t]):把一个表示时间的元组或者struct_time表示为这种形式:'Sun Jun 20 23:21:05 1993'。如果没有参数,将会将time.localtime()作为参数传入。



8)time.ctime([secs]):把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。如果参数未给或者为None的时候,将会默认time.time()为参数。它的作用相当于time.asctime(time.localtime(secs))。





9)time.strftime(format[, t]):把一个代表时间的元组或者struct_time(如由time.localtime()和time.gmtime()返回)转化为格式化的时间字符串。如果t未指定,将传入time.localtime()。如果元组中任何一个元素越界,ValueError的错误将会被抛出。

格式含义备注
%a本地(locale)简化星期名称
%A本地完整星期名称
%b本地简化月份名称
%B本地完整月份名称
%c本地相应的日期和时间表示
%d一个月中的第几天(01 - 31)
%H一天中的第几个小时(24小时制,00 - 23)
%I第几个小时(12小时制,01 - 12)
%j一年中的第几天(001 - 366)
%m月份(01 - 12)
%M分钟数(00 - 59)
%p本地am或者pm的相应符
%S秒(01 - 61)
%U一年中的星期数。(00 - 53星期天是一个星期的开始。)第一个星期天之前的所有天数都放在第0周。
%w一个星期中的第几天(0 - 6,0是星期天)
%W和%U基本相同,不同的是%W以星期一为一个星期的开始。
%x本地相应日期
%X本地相应时间
%y去掉世纪的年份(00 - 99)
%Y完整的年份
%Z时区的名字(如果不存在为空字符)
%%‘%'字符
备注:



“%p”只有与“%I”配合使用才有效果。
文档中强调确实是0 - 61,而不是59,闰年秒占两秒(汗一个)。
当使用strptime()函数时,只有当在这年中的周数和天数被确定的时候%U和%W才会被计算。
举个例子:

>>> time.strftime("%Y-%m-%d %X", time.localtime())



10)time.strptime(string[, format]):把一个格式化时间字符串转化为struct_time。实际上它和strftime()是逆操作。

>>> time.strptime('2018-01-08 21:07:06', '%Y-%m-%d %X')

strftime("格式",struct_time) ----->"格式化的字符串"
strptime("格式化的字符串","格式")----->struct_time
在这个函数中,format默认为:"%a %b %d %H:%M:%S %Y"。

最后,我们来对time模块进行一个总结。根据之前描述,在Python中共有三种表达方式:1)timestamp 2)tuple或者struct_time 3)格式化字符串。

它们之间的转化如图所示:





六、datetime 模块的一些用法

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: