time模块

在Python中,通常有这三种方式来表示时间:时间戳、元组(struct_time)、格式化的时间字符串:

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

(2)格式化的时间字符串(Format String): ‘1988-03-16’

(3)元组(struct_time) :struct_time元组共有9个元素共九个元素:(年,月,日,时,分,秒,一年中第几周,一年中第几天等)

 # <1> 时间戳
>>> import time
>>> time.time() #--------------返回当前时间的时间戳
1493136727.099066    #距离1970年1月1日00:00:00有这么多秒 # <2> 时间字符串
>>> time.strftime("%Y-%m-%d %X")
'2017-04-26 00:32:18' # <3> 时间元组
>>> time.localtime()
time.struct_time(tm_year=2017, tm_mon=4, tm_mday=26,
tm_hour=0, tm_min=32, tm_sec=42, tm_wday=2,
tm_yday=116, tm_isdst=0)

时间转换方法:

 print(time.localtime())  #时间对象,对象的数据类型一定可以通过这个对象进行.方法的操作
s=time.localtime() #结构化时间对象,以时间戳为参数
print(s.tm_year) #返回年份
print(time.gmtime()) #世家标准时间,和时区有关,也是用时间戳
print(time.mktime(time.localtime())) #将结构化时间转化成时间戳的方法

 print(time.asctime(time.localtime()))    #自动格式化当前时间
print(time.ctime(15352345134)) #自动格式化当前时间

手动格式化时间:

print(time.strftime('%Y-%m-%d',time.localtime()))   #结构化时间转化成字符串,分割符号-可以随意替换,可以是任意字符
print(time.strptime("2017-03-16","%Y-%m-%d")) #结构化时间转换成时间戳

小结:时间戳是计算机能够识别的时间;时间字符串是人能够看懂的时间;元组则是用来操作时间的

其他方法:

 time.sleep(3)    #睡眠3秒,用于延迟执行代码

random模块

随机数模块,能够按照指令使用对应的算法模拟随机数

 >>> import random
>>> random.random() # 大于0且小于1之间的小数
0.7664338663654585 >>> random.randint(1,5) # 大于等于1且小于等于5之间的整数
2 >>> random.randrange(1,3) # 大于等于1且小于3之间的整数
1 >>> random.choice([1,'',[4,5]]) # #1或者23或者[4,5]
1 >>> random.sample([1,'',[4,5]],2) # #列表元素任意2个组合
[[4, 5], ''] >>> random.uniform(1,3) #大于1小于3的小数
1.6270147180533838 >>> item=[1,3,5,7,9]
>>> random.shuffle(item) # 打乱次序
>>> item
[5, 1, 3, 7, 9]
>>> random.shuffle(item)
>>> item
[5, 9, 7, 1, 3]

应用示例:

 import random

 def v_code():
code = ''
for i in range(5):
num=random.randint(0,9)
alf=chr(random.randint(65,90))
add=random.choice([num,alf])
code="".join([code,str(add)])
return code
print(v_code())

hashlib模块

Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等。

什么是摘要算法呢?摘要算法又称哈希算法、散列算法。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。想要通过hash算法进行反推源数据是非常困难的,所以一般来讲,我们认为hash的值是不可逆的运算。

MD5计算:

 import hashlib
md5 = hashlib.md5()
md5.update('how to use md5 in python hashlib?')
print md5.hexdigest() 计算结果如下:
d26a53750bc40b38b65a520292f69306

如果数据量很大,可以分块多次调用update(),最后计算的结果是一样的:

 md5 = hashlib.md5()
md5.update('how to use md5 in ')  #必须是utf8编码
md5.update('python hashlib?')
print md5.hexdigest()

MD5是最常见的摘要算法,速度很快,生成结果是固定的128 bit字节,通常用一个32位的16进制字符串表示。另一种常见的摘要算法是SHA1,调用SHA1和调用MD5完全类似:

 import hashlib
sha1 = hashlib.sha1()
sha1.update('how to use sha1 in ')
sha1.update('python hashlib?')
print sha1.hexdigest()

SHA1的结果是160 bit字节,通常用一个40位的16进制字符串表示。比SHA1更安全的算法是SHA256和SHA512,不过越安全的算法越慢,而且摘要长度更长。

os模块

os模块是与操作系统交互的一个接口

 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd
os.curdir 返回当前目录: ('.')
os.pardir 获取当前目录的父目录字符串名:('..')
os.makedirs('dirname1/dirname2') 可生成多层递归目录
os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove() 删除一个文件
os.rename("oldname","newname") 重命名文件/目录
os.stat('path/filename') 获取文件/目录信息
os.sep 输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep 输出用于分割文件路径的字符串 win下为;,Linux下为:
os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix'
os.system("bash command") 运行shell命令,直接显示
os.environ 获取系统环境变量
os.path.abspath(path) 返回path规范化的绝对路径
os.path.split(path) 将path分割成目录和文件名二元组返回
os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path) 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path) 如果path是绝对路径,返回True
os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path) 返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小

optparse模块

该模块用于判断执行文件时候,捕获后边跟的选项和参数

创建执行文件

import optparse
def check_input():
parser = optparse.OptionParser()
parser.add_option("-i", "--server-ip", dest="server", help="ftp server ip_addr")
parser.add_option("-p", "--server-pport", type="int", dest="port", help="ftp server port")
parser.add_option("-U", "--username", dest="username", help="username info")
parser.add_option("-P", "--password", dest="password", help="password info")
print(parser.parse_args())
if __name__ == '__main__':
check_input()

第一个字段(一个-的字段):是输入的选项的简写形式

第二个字段(两个-的字段):是输入的选项的全写形式

dest:后面跟的是选项的参数名

help:是选项的帮助信息

type:限制选项的格式

在cmd窗口或shell中执行该文件

查看帮助信息

C:\Users\Mr.chai\Desktop\PythonProject>python optparse_test.py -h
Usage: optparse_test.py [options] Options:
-h, --help show this help message and exit
-i SERVER, --server-ip=SERVER
ftp server ip_addr
-p PORT, --server-pport=PORT
ftp server port
-U USERNAME, --username=USERNAME
username info
-P PASSWORD, --password=PASSWORD
password info

正常使用:

C:\Users\Mr.chai\Desktop\PythonProject>python optparse_test.py -i 192.168.1.1 -p 8888 -U root -P 8808
(<Values at 0x1c3ae7e79e8: {'server': '192.168.1.1', 'port': 8888, 'username': 'root', 'password': ''}>, [])

当输入的参数数量超出字典中的数量,会放到列表中存放

C:\Users\Mr.chai\Desktop\PythonProject>python optparse_test.py -i 192.168.1.1 -p 8888 -U root -P 8808 aaa bbb ccc ddd
(<Values at 0x218e9607ac8: {'server': '192.168.1.1', 'port': 8888, 'username': 'root', 'password': ''}>, ['aaa', 'bbb', 'ccc', 'ddd'])

等输入的选项没有设置,会提示没有该选项

C:\Users\Mr.chai\Desktop\PythonProject>python optparse_test.py -i 192.168.1.1 -p 8888 -U root -P 8808 -a
Usage: optparse_test.py [options] optparse_test.py: error: no such option: -a

选项可以不输入全

C:\Users\Mr.chai\Desktop\PythonProjec>python optparse_test.py -i 192.168.1.1 -p 8888
(<Values at 0x2440b477908: {'server': '192.168.1.1', 'port': 8888, 'username': None, 'password': None}>, [])

代码中的parser.parse_args()可以赋值给两个变量,输出结果就是那个字典和那个列表

d,l=parser.parse_args()
print(d)
print(l)

最新文章

  1. Codeforces Round #234A
  2. 【C语言学习】《C Primer Plus》第3章 数据和C
  3. HTML5中的sessionStorage和localStorage
  4. NBUT 1186 Get the Width(DFS求树的宽度,水题)
  5. 微信浏览器——User Agent
  6. [NYIST737]石子合并(一)(区间dp)
  7. Windows(Vertrigo)下Apache与Tomcat的整合
  8. stagefright框架(五)-Video Rendering
  9. 普林斯顿大学算法课 Algorithm Part I Week 3 求第K大数 Selection
  10. HDU 1847 Good Luck in CET-4 Everybody!
  11. C和指针 (pointers on C)——第十四章:预处理器
  12. Ajax的基本请求/响应模型
  13. java实现——008旋转数组的最小数字
  14. 谈谈一些有趣的CSS题目(十四)-- 纯 CSS 方式实现 CSS 动画的暂停与播放!
  15. Logistic回归计算过程的推导
  16. Lucene分词详解
  17. SCRUM管理之KPI与OKRs结合
  18. [新三板摘牌]国资企业济南华光光电去年终止拟IPO今年摘牌新三板
  19. CareerCup All in One 题目汇总
  20. ORACLE---OCP培训

热门文章

  1. 深入理解Spring MVC(山东数漫江湖)
  2. bzoj 1856 组合
  3. 结合promise对原生fetch的两个then用法理解
  4. js_微信分享,监听点击分享,分享成功,取消分享,分享失败回调
  5. zoj2001 Adding Reversed Numbers
  6. https 多路复用的理解~转载
  7. Vue组件-使用插槽分发内容
  8. KVM初始化过程
  9. linux命令(22):mkdir命令
  10. linux命令(15):mount/umount命令