编码和解码问题是编程很顽固的问题,有时候得encode和decode,有时候就不用,若出现错误 UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0xbf in position 7: invalid start byte 就是解码的问题,删了encode和decode的API试试看吧
1.相对路径和绝对路径
- 绝对路径——写完整的那种(在windows命令行中,不能直接跨盘寻找,需要先cd d:)
- 相对路径——相对当前路径来说的,就是从当前文件夹找寻你新输入的路径(如果不在同一文件夹下,则找不到)
2.工作目录的操作
- 目录就是路径,其实就是文件夹的组合
#os模块为系统内置的模块
import os
#拿到现在的工作目录
print(os.getcwd())
#修改工作目录
#os.chdir("C:/Windows")
#创建工作目录——用相对路径
#之所以该API有s是因为:创建一个路径,可能是包含多个文件夹的
os.makedirs("xx1/xx2")
#创建工作目录——用绝对路径
os.makedirs("D:/xx3")
3.txt文件的读取
- 读取为整个文件
#下面这行代码的意思就是,打开这个文件,作为file对象
file = open("C:/Users/Administrator/Desktop/python_skii/xx1/xx2/learn.txt")
#直接read,中文为乱码,所以需要先读取文件,以gbk读取,再decode解码为utf-8
content = file.read().encode('gbk').decode('utf-8')
#打开文件一定要记住关闭
file.close()
print(content)
#如果先decode,会出现错误 AttributeError: 'str' object has no attribute 'decode'
#原因:python3里面,字符串要先encode手动指定其为某一编码的字节码之后,才能decode解码。
- 读取为一行一行的
with open("C:/Users/Administrator/Desktop/python_skii/xx1/xx2/learn.txt") as file:
for line in file:
#如果不encode和decode,中文可能就会出现乱码
#print(line.encode('gbk').decode('utf-8').rstrip())
#.rstrip()为去除尾部空白
print(line.rstrip())
#之所以读出来每行有两次换行,是因为读取文件时,读到的是 numpy\n,,而print本身也带一个换行
- 读取为列表
with open("C:/Users/Administrator/Desktop/python_skii/xx1/xx2/learn.txt") as file:
lis = file.readlines()
print(str(lis).encode('gbk').decode('utf-8'))
4.txt文件的写入
# 括号中可以是前面运行出的数据,先将其转为字符串才能写入
result = str("\n运行出的数据\n")
# .txt可以不自己新建,代码会自动新建
with open('aaa.txt','a') as file:
# 写入,,, 有时放在循环里面需要自动转行,不然会覆盖上一条数据
#有这行的话,第二行不用转str也可以
file.write("{}\n".format(result))
5.异常处理
try:
print(9/1)
#如果尝试上面代码不行,则执行except下的代码,不会使得程序挂起
except:
print("出现错误了")
else:
print("没出现错误,则用else,但是这没啥用啊")
print("end")