文章目录
模块(module)
为了编写方便维护的代码,可以把不同功能的代码分组,保存在不同的文件里。
在python种,一个.py文件就可以被称为一个模块。
即:
- 包含相应功能的函数以及变量,py则以’.py’为后缀名;
- 模块可以被其他的程序引用,以使用该模块所对应的函数或者变量。
使用模块的优点:
- 提高代码的可维护性
- 提高代码的复用性
- 可以引入很多功能的模块
- 标准库模块
- 第三方模块
- 自定义模块
- 避免变量名重复(作用域)
python中导入模块的常用方式
- import 模块名
- import 模块名 as 新名称
- from 模块名 import 函数名
区别
-
import 模块名和import 模块名 as 新名称
- 会导入整个模块
- 如果我们需要使用某个函数,必须以’‘模块名.函数名()’‘的形式来调用相应的函数。这种方法可以更有利于代码的可读性(优先推荐的方法)
- import 模块名 as 新名称;重新命名导入的模块,通常使模块名称简洁,方便使用。
-
from 模块名 import 函数名
- 只导入了某一函数,而不是一整个模块
- 可以直接函数名去调用函数,而无需在函数名称前加模块名称
- 可能会造成函数名冲突,引发错误。
import …
import … as …
from … import 函数
import os
import random as rd
from math import exp
print(os.listdir())
print(rd.randint(10, 100))
print(exp(10))
#输出
['.idea', '1.py', '2.py', '3.py', '3.txt', '4.py', '4.txt', '5.py', '7.py', 'dictUser1.txt', 'GreenFlowerPorcelain.txt', 'test.txt', 'test1.py', 'test1.txt', 'test4', 'venv', 'work-1.py', 'work-2.py', 'work-3.py', 'work-4.py', 'work-5.py', 'work-6.py', 'work-7.py', 'yh.py', '浙江大学.txt', '青花瓷.txt']
63
22026.465794806718
注意:
import 语句的对应模块顺序(PEP)
- python标准模块
- 第三方
- 自定义模块
自定义模块
os模块
os模块是python标准库中用于访问操作系统功能的模块。
使用os模块提供的接口,能够实现跨平台访问。
最常见的操作:
- 目录的操作
- 判断
1.系统操作
-
os.sep:用于查看系统路径的分隔符;
- windows:’\‘
- ubuntu:’/’
-
os.name:显示我们正在使用的平台
- windows:‘nt’
- Linux/Unix:‘posix’
-
os.getenv():读取环境变量
-
os.getcwd():获取当前路径
import os
print(os.sep)
print(os.name)
print(os.getcwd())
#输出
\
nt
D:\STUDY\周日python学习\PycharmProjects\untitled
2.目录操作----增删改查
- os.listdir():查看路径下所有文件夹,若不给参数,则查看当前路径下所有文件夹
import os
print(os.listdir())
#输出
['.idea', '1.py', '2.py', '3.py', '3.txt', '4.py', '4.txt', '5.py', '7.py', 'dictUser1.txt', 'GreenFlowerPorcelain.txt', 'test.py', 'test.txt', 'venv', 'work-1.py', 'work-2.py', 'work-3.py', 'work-4.py', 'work-5.py', 'work-6.py', 'work-7.py', 'yh.py', '浙江大学.txt', '青花瓷.txt']
-
目录的创建
- os.mkdir(path):创建目录,单仅能创建一级目录
- 若path不存在测报错
- os.makedirs(path):创建目录,创建多级目录
- os.mkdir(path):创建目录,单仅能创建一级目录
-
目录/文件删除
- os.rmdir(path):删除目录(一级)
- os.removedirs(path):删除空目录(多级),只能删除空目录,当目录中有文件则不处理
- os.remove(path):删除文件,必须是文件
-
更改路径
- chdir():更改路径
os.chdir(’…’) #…表示上一级目录
- os.rename(old_name,new_name)
```python
os.rename('test.py','test1.py')
3.判断文件
-
os.path.exists(path):判断文件或者目录是否存在,存在返回True,不存在返回False
-
os.path.isfile(path):判断是否为文件,是,True;否,False
print(os.path.isfile('test1.py'))
#输出
True
- os.path.isdir(path):判断是否为文件夹,是,True;否,False
print(os.path.isdir('test1.py'))
#输出
False
拓展:
- os.path.dirname(path):返回文件路径
- os.path.basename(path):返回文件名称
- os.path.getsize(path):返回文件大小
- os.path.abspath(name):返回当前文件的绝对路径
- os.path.join(path,name):连接目录与文件名或者目录
- os.path.split(path):将path的目录和文件名分隔开,并返回元组
4.查看文件的时间
-
os.path.getmtime(path):返回文件或者目录的最后修改时间,结果为秒数
-
os.path.getatime(path):返回文件或者目录的最后访问时间,结果为秒数
-
os.path.getctime(path):返回文件或者目录的创建时间,结果为秒数
import time,os
print(time.strftime('%Y-%m-%d %X',time.localtime(os.path.getmtime('test1.py'))))
print(time.strftime('%Y-%m-%d %X',time.localtime(os.path.getatime('test1.py'))))
print(time.strftime('%Y-%m-%d %X',time.localtime(os.path.getctime('test1.py'))))
#输出
2019-07-22 17:22:32
2019-07-22 17:22:32
2019-07-22 17:22:32
5.获取文件目录
- os.walk(path)
import os
path=os.walk('..')
for i in path:
print(i)
#输出
('..', ['.idea', 'Django', 'djang_test', 'untitled', 'untitled1', 'yh1'], [])
...
('..\\yh1\\__pycache__', [], ['bank.cpython-37.pyc', 'function.cpython-37.pyc', 'welcome11111.cpython-37.pyc'])
6.文件操作
常见的文件类型:
- txt
- 文档文件
- csv
- 逗号分隔值文件格式
- json
- 数据交换格式
- html
- 超文本标记语音
- mp4
- 声音文件
文件操作的流程:
- 打开 —>open()
- 读/写 —>read()/write()
- 关闭 ---->close()
序号 | 用途 | 方法 | 功能 |
---|---|---|---|
1 | 打开/关闭文件 | f=open(file) | 打开文件 |
2 | close() | 关闭文件 | |
3 | 读写文件内容 | f.read([size]) | 从文件中读取指定的字节数;若未指定,读取所有。 |
4 | f.readline([size]) | 读取整行,包括‘\n’ | |
5 | f.readlines([size]) | 读取所有行,并返回列表 | |
6 | f.write(str) | 将字符串写入文件,并返回字符串长度 | |
7 | f.writelines(seq) | 向文件写入一个序列字符串列表。如果需要换行,需要自己加入换行符 | |
8 | f.flush() | 刷新文件缓存,直接把内部缓冲的数据写入文件 | |
9 | 文件的定位 | f.seek(offset) | 设置文件的当前位置,即指针位置 |
10 | f.tell() | 返回文件的当前位置,即指针位置 |
6.1 文件的打开和关闭
内置函数:open() ,创建一个file对象,之后才可以用它调用相关方法。
格式:
file_object = open(fifle,[,mode],[,encoding='utf-8'],[,buffering])
解释:
- file_object —>open()返回的文件对象
- file —>要打开的文件
- mode ----->指定模式:只读,写入,追加等等。表,一般默认只读
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。 |
w | 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
w+ | 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
-
encoding ------->指定文件编码,通常使用的是’utf-8‘/‘GBK’
-
buffering ------>若设置为0,不会有寄存;若设置为1,访问文件时会寄存行,若设为大于1的数,表明寄存区的缓冲大小,若设置为负数,则寄存区的缓存区大小为系统默认。
文件对象的属性
属性 | 描述 |
---|---|
f.name | 返回文件名称 |
f.mode | 返回打开文件的访问模式 |
f.closed | 如果文件已关闭,返回true;否则,false |
关闭
f.close()
节省计算机资源和提供性能,使用完文件之后,关闭它。
6.2 文件的读写
读
- f.read([size])
- 从文件指针处读取。
- 传递size,指定读取的字节数。
- readline()
- readlines()
写
- write()
- wirtelines()
定位读取
- f.tell()
- 获取文件的当前位置
- f.seek()
- 格式:
- offset,要移动的字节数
- from,指定偏移的参考位置,如果是0,从开头偏移,如果是1,从当前位置偏移,如果是2,从末尾开始偏移。
- 格式:
seek(offset[,from])
random模块
导入这个模块
import random
random模块的常见功能
- (1)random.random()
import random
a = random.random()
for i in range(100):
a = random.random()
print(a)
(2)random.uniform(a,b)
- 用于生成ab之间的随机浮点数,可以取到ab,但是概率感人。
import random
a = random.random()
for i in range(100):
a = random.uniform()
print(a)
(3)random.randint(a,b)
- 用于生成指定范围内的整数,[a,b]
import random
a = random.random()
for i in range(100):
a = random.randint(6,10)
print(a)
(4)random.randrange([start],stop,[step])
- 从指定范围内,按指定基数递增或递减的集合中,随机获取一个整数
a = random.randrange(1,16,2)
1,3,5,7,9,11,15,
第一次1-3取。第二次1-5取,以此类推。
(5)random.choice(sequence)
- 从序列中随机获取一个元素,sequence可以是列表,字符串,或者元组
(6)random.shuffle(x[,random])
- 用来将一个列表的元素打乱。即将列表的元素随机排列
import random
a = random.random()
li = [1,2,3,4,5,6,7,8,9,0]
for i in range(100):
random.shuffle(li)
print(li)
注意返回值为null,没有返回值,直接打乱
(7)random.sample(sequence,k)
- 用来从指定序列中随机获取指定长度的片段并随机排列,但不会修改原来的序列。
import random
a = random.random()
li = [1,2,3,4,5,6,7,8,9,0]
for i in range(100):
a=random.sample(li,4)
print(a)