time模块python
在Python中,一般有这几种方式来表示时间:算法
1 import time 2 3 # 1 time() :返回当前时间的时间戳 4 time.time() #1473835903.0278263 5 6 #---------------------------------------------------------- 7 8 # 2 localtime([secs]) 9 # 将一个时间戳转换为当前时区的struct_time。secs参数未提供,则以当前时间为准。 10 time.localtime() # time.struct_time(tm_year=2016, tm_mon=9, tm_mday=14, tm_hour=14, tm_min=53, tm_sec=18, tm_wday=2, tm_yday=258, tm_isdst=0) 11 time.localtime(1473835903.0278263) 12 13 #---------------------------------------------------------- 14 15 # 3 gmtime([secs]) 和localtime()方法相似,gmtime()方法是将一个时间戳转换为UTC时区(0时区)的struct_time。 16 17 #---------------------------------------------------------- 18 19 # 4 mktime(t) : 将一个struct_time转化为时间戳。 20 print(time.mktime(time.localtime()))#1473836098.0 21 22 #---------------------------------------------------------- 23 24 # 5 asctime([t]) : 把一个表示时间的元组或者struct_time表示为这种形式:'Sun Jun 20 23:21:05 1993'。 25 # 若是没有参数,将会将time.localtime()做为参数传入。 26 print(time.asctime())#Wed Sep 14 14:55:39 2016 27 28 #---------------------------------------------------------- 29 30 # 6 ctime([secs]) : 把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。若是参数未给或者为 31 # None的时候,将会默认time.time()为参数。它的做用至关于time.asctime(time.localtime(secs))。 32 print(time.ctime()) #Wed Sep 14 14:55:39 2016 33 34 print(time.ctime(time.time())) # Wed Sep 14 14:55:39 2016 35 36 # 7 strftime(format[, t]) : 把一个表明时间的元组或者struct_time(如由time.localtime()和 37 # time.gmtime()返回)转化为格式化的时间字符串。若是t未指定,将传入time.localtime()。若是元组中任何一个 38 # 元素越界,ValueError的错误将会被抛出。 39 print(time.strftime("%Y-%m-%d %X", time.localtime())) # 2016-09-14 14:58:12 40 41 # 8 time.strptime(string[, format]) 42 # 把一个格式化时间字符串转化为struct_time。实际上它和strftime()是逆操做。 43 print(time.strptime('2016-09-14 14:58:12', '%Y-%m-%d %X')) 44 45 # time.struct_time(tm_year=2016, tm_mon=9, tm_mday=14, tm_hour=14, tm_min=58, tm_sec=12, tm_wday=2, tm_yday=258, tm_isdst=-1) 46 47 #在这个函数中,format默认为:"%a %b %d %H:%M:%S %Y"。 48 49 50 # 9 sleep(secs) 51 # 线程推迟指定的时间运行,单位为秒。 52 53 # 10 clock() 54 # 这个须要注意,在不一样的系统上含义不一样。在UNIX系统上,它返回的是“进程时间”,它是用秒表示的浮点数(时间戳)。 55 # 而在WINDOWS中,第一次调用,返回的是进程运行的实际时间。而第二次以后的调用是自第一次调用之后到如今的运行 56 # 时间,即两次时间差。
帮助信息shell
help(time)
help(time.asctime)
datetime模块数据库
import datetime # print(datetime.datetime.now()) #返回 2016-09-14 15:09:09.555727 # print(datetime.date.fromtimestamp(time.time()) ) # 时间戳直接转成日期格式 2016-09-14 # 时间加减 # 对日期和时间进行加减实际上就是把datetime日后或往前计算,获得新的datetime。 # now = datetime.datetime.now() # now + datetime.timedelta(3)) #当前时间+3天 # now + datetime.timedelta(-3)) #当前时间-3天 # now+ datetime.timedelta(hours=3)) #当前时间+3小时 # now + datetime.timedelta(minutes=30)) #当前时间+30分 # c_time = datetime.datetime.now() # print(c_time.replace(minute=3,hour=2)) #时间替换
random 模块bash
1 import random 2 3 print(random.random()) # (0,1)随机浮点数 4 print(random.randint(1, 3)) # 随机1-3整数,便是一、二、3 5 print(random.randrange(1, 3)) # 随机1-3整数,不包括3 6 print(random.choice([1, "23", [4, 5]])) # n个元素中选一个 7 print(random.sample(['123', 4, [1, 6], 9], 3)) # 从n个元素中选择指定个数,这里是3 8 print(random.uniform(1, 5)) # 生成随机浮点数 9 10 11 # 生成随机验证码 12 def v_code(): 13 code='' 14 for i in range(5): 15 add = random.choice([random.randrange(10),chr(random.randrange(65,91))]) 16 code += str(add) 17 18 print(code) 19 v_code()
os 模块app
os是与操做系统交互的一个接口运维
1 os.getcwd() 获取当前工做目录,即当前python脚本工做的目录路径 2 os.chdir("dirname") 改变当前脚本工做目录;至关于shell下cd 3 os.curdir 返回当前目录: ('.') 4 os.pardir 获取当前目录的父目录字符串名:('..') 5 os.mkdir('dirname') 生成单级目录;至关于shell中mkdir dirname 6 os.rmdir('dirname') 删除单级空目录,若目录不为空则没法删除,报错;至关于shell中rmdir dirname 7 os.makedirs('dirname1/dirname2') 可生成多层递归目录 8 os.listdir('dirname') 列出指定目录下的全部文件和子目录,包括隐藏文件,并以列表方式打 9 os.remove() 删除一个文件 10 os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推 11 os.rename("oldname","newname") 重命名文件/目录 # abc.txt与abc是两个文件 12 os.stat('path/filename') 获取文件/目录信息 13 os.sep 输出操做系统特定的路径分隔符,win下为"\\",Linux下为"/" 14 os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n" 15 os.pathsep 输出用于分割文件路径的字符串 16 os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix' 17 os.system("bash command") 运行shell命令,直接显示 18 os.environ 获取系统环境变量 19 os.path.abspath(path) 返回path规范化的绝对路径 20 os.path.split(path) 将path分割成目录和文件名二元组返回 21 os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素 22 os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径以前的参数将被忽略
sys模块dom
提供对解释器相关的操做ide
1 sys.argv 命令行参数List,第一个元素是程序自己路径 2 sys.exit(n) 退出程序,正常退出时exit(0) 3 sys.version 获取Python解释程序的版本信息 4 sys.maxint 最大的Int值 5 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 6 sys.platform 返回操做系统平台名称 7 sys.stdout.write('please:') 8 val = sys.stdin.readline()[:-1]
9 sys.path.append() 改变模块的搜索目录
hashlib 模块函数
Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等。
什么是摘要算法呢?摘要算法又称哈希算法、散列算法。它经过一个函数,把任意长度的数据转换为一个长度固定的数据串(一般用16进制的字符串表示)。
摘要算法就是经过摘要函数f()
对任意长度的数据data
计算出固定长度的摘要digest
,目的是为了发现原始数据是否被人篡改过。
摘要算法之因此能指出数据是否被篡改过,就是由于摘要函数是一个单向函数,计算f(data)
很容易,但经过digest
反推data
却很是困难。并且,对原始数据作一个bit的修改,都会致使计算出的摘要彻底不一样。
咱们以常见的摘要算法MD5为例,计算出一个字符串的MD5值:
1 import hashlib 2 3 md5 = hashlib.md5() 4 md5.update('how to use md5 in python hashlib?'.encode('utf-8')) 5 print(md5.hexdigest())
计算结果以下:
d26a53750bc40b38b65a520292f69306
若是数据量很大,能够分块屡次调用update()
,最后计算的结果是同样的:
import hashlib md5 = hashlib.md5() md5.update('how to use md5 in '.encode('utf-8')) md5.update('python hashlib?'.encode('utf-8')) print(md5.hexdigest())
另外一种常见的摘要算法是SHA1,调用SHA1和调用MD5彻底相似:
1 import hashlib 2 3 sha1 = hashlib.sha1() 4 sha1.update('how to use sha1 in '.encode('utf-8')) 5 sha1.update('python hashlib?'.encode('utf-8')) 6 print(sha1.hexdigest())
摘要算法能应用到什么地方?举个经常使用例子:
任何容许用户登陆的网站都会存储用户登陆的用户名和口令。如何存储用户名和口令呢?方法是存到数据库表中
若是以明文保存用户口令,若是数据库泄露,全部用户的口令就落入黑客的手里。此外,网站运维人员是能够访问数据库的,也就是能获取到全部用户的口令。
正确的保存口令的方式是不存储用户的明文口令,而是存储用户口令的摘要