15. 常用模块(time/os/sys)

[TOC]

初涉模块

在python中,能开辟自己作用域的只有函数、类以及模块
for循环if-else循环均不能实现开辟自己的作用域。

>>> x = 3
>>> for i in range(10):
...     x = 55
...
...
>>> print(x)
55

“模块就是.py文件”

import xxxxx

time

  • 时间戳:
>>> time.time()
1493168755.906269
  • 时间字符串
>>> time.strftime('%Y-%m-%d %X')
'2017-04-26 09:06:58'

小写的y表示后两位的年份
后面的M和m分别代表分钟数(minutes)和月份(month)

Commonly used format codes:

    %Y  Year with century as a decimal number.
    %m  Month as a decimal number [01,12].
    %d  Day of the month as a decimal number [01,31].
    %H  Hour (24-hour clock) as a decimal number [00,23].
    %M  Minute as a decimal number [00,59].
    %S  Second as a decimal number [00,61].
    %z  Time zone offset from UTC.
    %a  Locale's abbreviated weekday name.
    %A  Locale's full weekday name.
    %b  Locale's abbreviated month name.
    %B  Locale's full month name.
    %c  Locale's appropriate date and time representation.
    %I  Hour (12-hour clock) as a decimal number [01,12].
    %p  Locale's equivalent of either AM or PM.

  • 结构化时间
>>> time.localtime()
time.struct_time(tm_year=2017, tm_mon=4, tm_mday=26, tm_hour=9, tm_min=15, tm_sec=13, tm_wday=2, tm_yday=116, tm_isdst=0)

tm_isdst----夏令时

>>> c = time.localtime()
>>> c.tm_year
2017

结构化时间就是用来对时间进行操作的

>>> help(time.localtime)
Help on built-in function localtime in module time:

localtime(...)
    localtime([seconds]) -> (tm_year,tm_mon,tm_mday,tm_hour,tm_min,
                              tm_sec,tm_wday,tm_yday,tm_isdst)

    Convert seconds since the Epoch to a time tuple expressing local time.
    When 'seconds' is not passed in, convert the current time instead.

时间形式的转换

时间戳
||

mktime/
>>> time.mktime(time.localtime())
1493170076.0

||

格式化时间
strftime/strptime

>>> time.strftime('%Y-%m-%d %X',time.localtime(time.time()-24*3600))
'2017-04-25 09:33:00'

||

time.ctime()
time.asctime()

随机数模块random

random.random()
默认0-1取浮点数
规定范围取浮点数

>>> random.uniform(1,3)
2.969686720232199

范围取整

>>> random.randint(1,9)
5
>>> random.randint(1,9)
4
>>> random.randint(1,9)
1
>>> random.randrange(1,9)
6
>>>
>>> random.randrange(1,9)
2

规定范围取值

>>> random.choice(['a','b','c','d'])
'c'
>>> random.choice(['a','b','c','d'])
'c'
>>> random.choice(['a','b','c','d'])
'a'
>>> random.choice(['a','b','c','d'])
'b'
>>> random.choice(['a','b','c','d'])
'a'

规定范围取多个值

>>> random.sample(['a','b','c','d'],2)
['a', 'c']

随机排序

>>> item = [1,2,4,5,9,6,3]
>>> random.shuffle(item)
>>> item
[4, 6, 5, 1, 2, 3, 9]

应用实例:生成五位验证码

import random
def validate():
    l=[chr(i) for i in range(97,123)]
    l.extend([1,22])
    # .extend方法就是一个操作,没有返回值
    item  =random.sample(l,5)
    sumstr = ''
    for i in item:
        sumstr += i
    print(sumstr)

validate()

hashlib

摘要算法

计算一个字符串的md5值

>>> import hashlib
>>> m = hashlib.md5()
>>> m.update('scott')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: Unicode-objects must be encoded before hashing
>>> m.update(b'scott')
>>> print(m.hexdigest())
21f63c6e971cd913a9c147e8652ca659
import hashlib
m= hashlib.md5()
m.update('alex'.encode('utf8'))

print(m.hashdigest())

os模块

import os

# 当前工作目录
>>> os.getcwd()
'D:\\Users\\sss'

# 修改当前工作目录
>>> os.chdir('I:')
>>> os.getcwd()
'I:\\'

# 创建文件
>>> os.makedirs('aaa/bbb')
# 删除文件
>>> os.removedirs('aaa/bbb')
# 如果文件不为空,则无法删除
>>> os.rmdir('aaa/bbb')

# 查看当前的文件夹内容
>>> os.listdir()
['$RECYCLE.BIN', 'cn_windows_10_enterprise_x64_dvd_6846957', 'System Volume Information', '~putfile0.im_', '游戏']

# 查看文件状态
>>> os.stat('游戏')
os.stat_result(st_mode=16895, st_ino=13510798882112605, st_dev=1009602189, st_nlink=1, st_uid=0, st_gid=0, st_size=98304, st_atime=1493138044, st_mtime=1493138044, st_ctime=1492582673)

os.system


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

>>> os.system('dir')
 驱动器 I 中的卷没有标签。
 卷的序列号是 3C2D-4E8D

 I:\ 的目录

2017/03/25  23:54    <DIR>          cn_windows_10_enterprise_x64_dvd_6846957
2017/03/26  00:43       185,526,784 ~putfile0.im_
2017/04/26  00:34    <DIR>          游戏
               1 个文件    185,526,784 字节
               2 个目录 29,074,653,184 可用字节
0

#获取绝对路径
>>> os.path.abspath('游戏')
'I:\\游戏'

>>> b = os.path.basename('I:\\游戏')
>>> d = os.path.dirname('I:\\游戏')
>>> print(d,b)
I:\ 游戏

# 操作系统的特定分隔符
>>> print(d+os.sep+b)
I:\\游戏

# 正确的拼接路径方式
>>> os.path.join(d,b)
'I:\\游戏'

sys

sys.argv 命令行参数List,第一个元素是程序本身路径
sys.exit(n) 退出程序,正常退出时exit(0)

sys.version 获取Python解释程序的版本信息
sys.maxint 最大的Int值
sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
sys.platform 返回操作系统平台名称

>>> import sys
>>> sys.version
'3.6.1 (v3.6.1:69c0db5, Mar 21 2017, 18:41:36) [MSC v.1900 64 bit (AMD64)]'

# sys.argv

>>> sys.path
['', 'D:\\Program Files\\Python36\\python36.zip', 'D:\\Program Files\\Python36\\DLLs', 'D:\\Program Files\\Python36\\lib', 'D:\\Program Files\\Python36', 'D:\\Program Files\\Python36\\lib\\site-packages']

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容