5 Jun 18 复习,模块

5 Jun 18 复习,内置模块与第三方模块

一、time与datetime

import time

# 时间戳(timestamp):通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。

print(time.time())  # 1528188733.8373

# 格式化的时间字符串(Format String)

print(time.strftime("%Y-%m-%d %X"))  # 2018-06-05 16:52:13

# 结构化的时间(struct_time):struct_time元组共有9个元素共九个元素:(年,月,日,时,分,秒,一年中第几周,一年中第几天,夏令时)

print(time.localtime())  # time.struct_time(tm_year=2018, tm_mon=6, tm_mday=5, tm_hour=16, tm_min=52, tm_sec=13, tm_wday=1, tm_yday=156, tm_isdst=0)

print(time.gmtime())  # time.struct_time(tm_year=2018, tm_mon=6, tm_mday=5, tm_hour=8, tm_min=52, tm_sec=13, tm_wday=1, tm_yday=156, tm_isdst=0)

# 转换

print(time.localtime(time.time()))

print(time.gmtime(time.time()))

print(time.mktime(time.localtime()))  # 1528189230.0

print(time.strftime("%Y-%m-%d %X",time.gmtime()))  # 2018-06-05 09:00:30

print(time.strptime('2011-05-05 16:37:06', '%Y-%m-%d %X'))

# 如果没有参数,将会将time.localtime()作为参数传入。

print(time.asctime())  # Tue Jun 5 17:02:46 2018

# 如果参数未给或者为None的时候,将会默认time.time()为参数

print(time.ctime())  # Tue Jun 5 17:03:04 2018

print(time.ctime(time.time()))  # Tue Jun 5 17:03:27 2018

time.sleep(2)

import datetime

# 时间加减

print(datetime.datetime.now())  # 2018-06-05 17:08:50.554154

print(datetime.date.fromtimestamp(time.time()))  # 2018-06-05

print(datetime.datetime.now()+datetime.timedelta(3))  # 2018-06-08 17:08:50.554274

print(datetime.datetime.now()+datetime.timedelta(-3))  # 2018-06-02 17:08:50.554300

print(datetime.datetime.now() + datetime.timedelta(hours=3))  # 2018-06-05 20:08:50.554319

print(datetime.datetime.now() + datetime.timedelta(minutes=30))  # 2018-06-05 17:38:50.554345

# 时间替换

c_time = datetime.datetime.now()

print(c_time.replace(minute=3,hour=2)) #2018-06-05 02:03:53.562862

二. random模块

import random

print(random.random())  # 0.6314922538999044   大于0且小于1之间的小数

print(random.randint(1,3))  # 3    大于等于1且小于等于3之间的整数

print(random.randrange(1,3)) # 2    大于等于1且小于3之间的整数

print(random.choice([1,'23',[4,5]]))  # 1或者23或者[4,5]

print(random.sample([1,'23',[4,5]],2))  # 列表元素任意2个组合

print(random.uniform(1,3))  # 大于1小于3的小数,如1.927109612082716

item=[1,3,5,7,9]

random.shuffle(item) # 打乱item的顺序,相当于"洗牌"

print(item) # [3, 5, 1, 7, 9]

# 生成随机验证码

def make_code(n):

   res=''

   for i in range(n):

       s1=chr(random.randint(65,90))

       s2=str(random.randint(0,9))

       res+=random.choice([s1,s2])

   return res

print(make_code(9))  # TXGIS35Q3

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

import 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下为" ",Linux下为" "

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的大小

os.path.normcase('c:/windows\system32\')

四.sys模块

import sys

sys.argv           命令行参数List,第一个元素是程序本身路径

sys.exit(n)        退出程序,正常退出时exit(0)

sys.version        获取Python解释程序的版本信息

sys.maxint         最大的Int值

sys.path           返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值

sys.platform       返回操作系统平台名称

# 进度条

import sys

import time

def progress(percent,width=50):

   if percent>=1:

       percent=1

   show_str=('[%%-%ds}' %width)%(int(width*percent)*'#')

   print(' %s %d%%' % (show_str,int(100*percent)),file=sys.stdout,flush=True,end='')

data_size=1025

recv_size=0

while recv_size<data_size:

   time.sleep(0.1)

   recv_size+=100

   percent=recv_size/data_size

   progress(percent,width=70)

五. shutil模块(高级的 文件、文件夹、压缩包 处理模块)

六. json & pickle模块

# 无论数据是怎样创建的,只要满足json格式,就可以json.loads出来,不一定非要dumps的数据才能loads

import json

dic={'name':'alvin','age':23,'sex':'male'}

print(type(dic))  # <class 'dict'>

j=json.dumps(dic)

print(type(j))  # <class 'str'>

f=open('序列化对象','w')

f.write(j)

f.close()

import json

f=open('序列化对象')

data=json.loads(f.read())

import pickle

dic={'name':'alvin','age':23,'sex':'male'}

print(type(dic))  # <class 'dict'>

j=pickle.dumps(dic)

print(type(j))  # <class 'bytes'>

f=open('序列化对象_pickle','wb')

f.write(j)

f.close()

import pickle

f=open('序列化对象_pickle','rb')

data=pickle.loads(f.read())

print(data['age'])

七. hashlib模块

import hashlib

m=hashlib.md5()

m.update('hello'.encode('utf8'))

print(m.hexdigest())  # 5d41402abc4b2a76b9719d911017c592

m.update('alvin'.encode('utf8'))

print(m.hexdigest())  # 92a7e713c30abbb0319fa07da2a5c4af

m2=hashlib.md5()

m2.update('helloalvin'.encode('utf8'))

print(m2.hexdigest())  # 92a7e713c30abbb0319fa07da2a5c4af

八. re模块

九. pymysql模块

原文地址:https://www.cnblogs.com/zhangyaqian/p/py201806050.html