1.os 模块
对于文件和目录进行解决
目录:就是文件夹
属性:
os.name:查看以后零碎的类型;
如果是 windows —> nt
如果是 max —> posix
os.environ:返回以后零碎的环境变量(所有)
函数:
os.environ.get():获取指定的某一个环境变量
门路分类:
绝对路径:带盘符根目录的就是绝对路径
pyhton
相对路径:绝对于某个文件 (参照物) 所失去的一个门路值; 特点:书写的时候不带盘符的
os.getcwd():返回以后正在执行的.py 文件所对应的残缺门路(绝对路径)
os.listdir(path):将 path 门路下的所有文件和目录显示
os.mkdir(path):创立单层文件夹, 此办法只能创立目录,如果目录曾经存在,创立失败,报错
os.makedirs(path):创立多层文件夹(级联新建),此办法也只能创立目录,如果目录曾经存在,创立失败,报错
os.rmdir(path):删除单层文件夹, 此办法只能删除页游目录,如果目录不存在,删除失败,报错:FileNotFoundError
os.removedirs(path):删除多层文件夹(级联删除),此办法也只能删除目录,如果目录不存在,创立失败,报错
os.remove(path):删除文件,如果文件不存在,报错!【留神】这个办法只能删除文件不能删除目录
os.rename(old, new):能够给文件或者目录重命名
os.system():执行零碎指令:cls、ipconfig、www.sangpi.comdir。。。
os.path.join(path, fileName):将 path 和 fileName 中的数据拼接称为一个新的门路,以字符串的模式返回
os.path.isdir(path):判断 path 对应的门路内容是否为一个目录,如果是,返回 True; 反之,返回 False
os.path.isfile(path):判断 path 对应的门路内容是否为一个文件,如果是,返回 True; 反之,返回 False
os.path.exists(path):判断 path 对应的门路内容是否存在,如果存在,返回 True; 反之,返回 False
os.path.getsize(path):对 path 对应的门路内容进行容量检测,并且返回字节量
os.path.basename(path):传入一个门路值,将此门路的最初一个 / 前面的局部返回
os.path.dirname(path): 传入一个门路值,将此门路的最初一个 / 后面的局部返回
os.path.split(path):传入一个门路值,将此门路的最初一个 / 的后面局部放入到元祖的第一个元素中,
/ 前面的局部放入到元祖的第二个元素中
os.path.splitext(path):传入一个门路值,将此门路的最初一个. 的后面局部放入到元祖的第一个元素中,
以及前面的局部放入元祖的第二个元素中
1. 字符集(字符编码):
ascii 码:
美国的规范码,范畴:本人去找找看
unicode 码:
万国码,它能够蕴含中文,然而很惋惜,它不被通用(风行)
utf- 8 码:
计算机中应用最为风行,它蕴含了之前 unicode 中的内容并且扩大了,
它同样能够保留中文
utf- 8 码保留中文字符,一个汉字占用 3 个字节,
gbk 码:
咱们中国的码表,它同样继承了 gb2312,次要用于一些中文的零碎
gbk 保留中文字符,1 个汉字占用内存 2 个字节,
2. 字节和字符
记住:计算机中所有皆字节(存储方面)
字符:咱们应用文本编辑器关上,可能看得懂的(不会乱码),就是字符文件
字节:咱们应用文本编辑器关上,不可能看懂的,就是字节文件
思考:.doc 结尾的文件是字符文件吗?
不是;
3. 文件读取
有规定的步骤:
1). 关上文件
2). 操作数据(读、写)
3). 敞开文件 **
关上文件:
fp= open(path, 打开方式, encoding=,errors=’Ignore’)
操作数据:
打开方式:
’r’:示意只读字符(readonly)
#’r+’:在只读的性能下,在追加一个写的性能
’w’:示意只写字符(readwrite),第一次写完,如果没有敞开文件,持续写,那么会将本来的内容笼罩
#’w+’:在只写的性能下,在追加一个读的性能
’a’:示意追加内容
#’a+’:在保留追加内容的同时,新增了一个读的性能
’rb’:示意只读字节(二进制数据)
’wb’:示意只写字节(二进制数据)
encoding:
编码集如果不显示定义,对应的就是:gbk
咱们也能够依据本人的须要,定义譬如:utf-8
errors:
如果不写,默认是报错(编解码不统一)
咱们也能够定义为 ignore,这样就不会报错了,然而会呈现乱码
编码 & 解码:
编码:程序 —> 文件
解码:文件 —> 程序
记住:如果编码和解码不统一,肯定会乱码(中文状况下)
读取文件中的数据:
fp= open(path,‘r’)
content= fp.read() #读取全部内容
content= fp.read(num) #读取 num 个字节数
content= fp.readline() #读取一行数据
content= fp.readlines() #读取所有行,以一个列表的模式返回
print(content) #打印读取到的内容
【留神】读文件,如果文件不存在,间接报错:FileNotFoundError
写入数据到文件中:
fw= open(path, ‘w’)
fw.write(str1) #将变量 str1 中的内容写入到 path 对应的文件中(笼罩)
【留神】写文件,如果文件不存在,先创立文件,再写入内容; 如果存在了,将以前的内容笼罩
fw = open(path, ‘a’)
fw.write(str1) #将变量 str1 中的内容写入到 path 对应的文件中(追加)
敞开文件:
fp.close() #敞开文件(开释资源)