一、相对路径和绝对路径

    1. 绝对路径:从磁盘根⽬录开始⼀直到⽂件名.

    2. 相对路径:同⼀个⽂件夹下的⽂件. 相对于当前这个程序所在的⽂件夹⽽⾔. 如果在同⼀个⽂件夹中. 则相对路径就是这个⽂件名. 如果在上⼀层⽂件夹. 则要使用“../”退回到上一个文件夹,再去查找相应的文件夹和文件。

    如下是相对路径:

                                                                      

      绝对路径如下:

                                                                                           

 

二、 初识⽂件操作

    使⽤python来读写⽂件是非常简单的操作. 我们使⽤open()函数来打开⼀个⽂件, 获取到⽂件句柄. 然后通过⽂件句柄就可以进⾏各种各样的操作了. 根据打开⽅式的不同能够执⾏的  操作也会有相应的差异.

    打开⽂件的⽅式: r, w, a, r+, w+, a+, rb, wb, ab, r+b, w+b, a+b 默认使⽤的是r(只读)模式

   1.read() 将⽂件中的内容全部读取出来. 弊端: 占内存. 如果⽂件过⼤.容易导致内存崩溃

 

f = open("test.txt", mode="r", encoding="utf-8")#在此py文件下,新建一个test.txt的文件
content = f.read()
print(content)

  

   2. read(n) 读取n个字符. 需要注意的是. 如果再次读取. 那么会在当前位置继续去读⽽不是从头读, 如果使⽤的是rb模式. 则读取出来的是n个字节。

f = open("test.txt", mode="r" encoding="utf-8")
content = f.read(3)
print(content) 

    3. readline() ⼀次读取⼀⾏数据, 注意: readline()结尾, 注意每次读取出来的数据都会有⼀

  个\n 所以呢. 需要我们使⽤strip()⽅法来去掉\n或者空格

f = open("../def/哇擦.txt", mode="r", encoding="utf-8")
content = f.readline()
print(content)

    4. readlines()将每⼀⾏形成⼀个元素, 放到⼀个列表中. 将所有的内容都读取出来. 所以也是容易出现内存崩溃的问题.不推荐使⽤

f = open("test.txt", mode="r", encoding="utf-8")
lst = f.readlines()
print(lst)
for line in lst:
  print(line.strip())

    5. 循环读取. 这种⽅式是组好的. 每次读取⼀⾏内容.不会产⽣内存溢出的问题

   f = open("test.txt", mode="r", encoding="utf-8")

    for line in f:

    print(line.strip())

    6.注意: 读取完的⽂件句柄⼀定要关闭 f.close()

. 写模式(w, wb)

  写的时候注意. 如果没有⽂件. 则会创建⽂件, 如果⽂件存在. 则将原件中原来的内容删除, 再写入新内容

f = open("test.txt", mode="w", encoding="utf-8")

f.write("test0001")

f.flush() # 刷新. 养成好习惯

f.close()

wb模式下. 可以不指定打开⽂件的编码. 但是在写⽂件的时候必须将字符串转化成utf-8bytes数据

f = open("test.txt", mode="wb")
f.write("test0002".encode("utf-8"))
f.flush()
f.close()

. 追加(a, ab)

 在追加模式下. 我们写入的内容会追加在⽂件的结尾。有这个文件,则会在末尾追加。如果没有此文件,则会创建。

f = open("test.txt", mode="a", encoding="utf-8")
f.write("张三的最爱")
f.flush()
f.close()

  ab模式代码如下:

f = open("test.txt", mode="ab")
f.write("麻花藤的最爱".encode('utf-8'))
f.flush()
f.close()

. 读写模式(r+, r+b)

  对于读写模式. 必须是先读. 因为默认光标是在开头的. 准备读取的. 当读完了之后再进⾏写入. 我们以后使⽤频率最⾼的模式就是r+

f = open("test.txt", mode="r+", encoding="utf-8")
content = f.read()
f.write("麻花藤的最爱")
print(content)
f.flush()
f.close()

注意:r+模式下. 必须是先读取. 然后再写入

. 写读(w+, w+b)

    先将所有的内容清空. 然后写入. 最后读取. 但是读取的内容是空的, 不常⽤。 w+ 模式下, ⼀开始读取不到数据. 然后写的时候再将原来的内容清空. 所以, 很少⽤。

f = open("test.txt", mode="w+", encoding="utf-8")
f.write("哈哈")
content = f.read()
print(content)
f.flush()
f.close()

. 追加读(a+)

   a+模式下, 不论先读还是后读. 都是读取不到数据的

f = open("⼩娃娃", mode="a+", encoding="utf-8")
f.write("⻢化腾")
content = f.read()
print(content)
f.flush()
f.close()

还有⼀些其他的带b的操作. 就不多赘述了. 就是把字符换成字节. 仅此⽽已

. 其他相关操作

1. seek(n) 光标移动到n位置, 注意, 移动的单位是byte. 所以如果是UTF-8的中部分要3的倍数.通常我们使⽤seek都是移动到开头或者结尾.

   移动到开头: seek(0)

   移动到结尾: seek(0,2) seek的第⼆个参数表⽰的是从哪个位置进⾏偏移, 默认是0, ⽰开头, 1表⽰当前位置, 2表⽰结尾.

   使用时,不知道有没有遇到这个错误:io.UnsupportedOperation: can't do nonzero cur-relative seeks

  这个问题主要是因为在python3和python2的问题,如果在Python2中是不会报错的,Python3则会报错。因为Pyhon3在文本文件中,没有使用b模式选项打开的文件,只允许从   文件头开始计算相对位置,从文件尾计算时就会引发异常

f = open("test.txt", mode="rb")
f.seek(0)  # 光标移动到开头
content = f.read()  # 读取内容, 此时光标移动到结尾
print(content)
print(f.tell())
f.seek(-3, 1)  # 再次将光标移动到开头
content = f.read(6)  # 读取内容, 此时光标移动到结尾
print(content)
print(f.tell())
f.flush()
f.close()

2.tell()方法也使用了,就是告诉用户,当前光标在什么位置。计算时,是按照,字节数累加的。

3.truncate()

此方法的作用就是,删除光标后面的所有内容。如果truncate()括号内,填入值,就是只保留这几个值,其余的全部删除。

f = open('test.txt',mode='w',encoding='utf-8')#此行代码执行后,文件中就没有文字了,所以需要下面的f.write('哈呵护'),写入一些值。这是因为‘w’模式就是这个特点。
f.write('哈呵护')
c = f.seek(6)
print(c)
f.truncate()



f = open('test.txt', mode='r+', encoding='utf-8')
print(f.read())
f.seek(0)
f.seek(3)
f.truncate()
print(f.read())

f = open('test.txt', mode='r+', encoding='utf-8')
f.truncate(6)#这里对的数字代表,截取的是字节,如果utf-8编码格式的汉字,3个字节代表一个。

  

. 修改⽂件以及另⼀种打开⽂件的⽅式

 ⽂件修改: 只能将⽂件中的内容读取到内存中, 将信息修改完毕, 然后将源⽂件删除, 将新⽂件的名字改成老⽂件的名字.

# ⽂件修改

import os
with open("test.txt", mode="r", encoding="utf-8") as f1,\
 open("test_new.txt", mode="w", encoding="UTF-8") as f2:
 content = f1.read()
 new_content = content.replace("冰糖葫芦", "⼤⽩梨")
 f2.write(new_content)
os.remove("⼩娃娃") # 删除源⽂件
os.rename("test_new.txt", "⼩娃娃") # 重命名新⽂件
弊端: ⼀次将所有内容进⾏读取. 内存溢出. 解决⽅案: ⼀⾏⼀⾏的读取和操作

import os
with open("test.txt", mode="r", encoding="utf-8") as f1,\
 open("⼩娃娃_new", mode="w", encoding="UTF-8") as f2:
 for line in f1:
 new_line = line.replace("⼤⽩梨", "冰糖葫芦")
 f2.write(new_line)
os.remove("test.txt") # 删除源⽂件
os.rename("test_new.txt", "test.txt") # 重命名新⽂件