1、背景
使用python处理一些css文件,替换里面的一些路径。
2、问题:使用以下代码进行处理时,最后一行总是多出来一些字符串(多出来的字符串个数=替换前后相减后的差)
#-*-coding:utf-8-*-
import os
filepath = "./dist/"
files = os.listdir(filepath)
for file in files:
if ".css" in file :
with open(filepath+file,'r+', encoding='UTF-8') as f:
# 读取文件 此时文件指针指到文件结尾
text = f.read()
# 清空文件
f.truncate()
# 重置文件指针为文件开头位置
f.seek(0)
# 替换字符串
text = str(text).replace("https://at.alicdn.com/t","assets/font")
# 将替换后的字符串写入
f.write(text)
# 关闭
f.close()
3、原因:
read()执行后文件指针指向的是文本末尾,此时执行truncate()清除文本,相当于没有清除,并且此时调用seek(0)重新设置文本指针为起始位置,重新写入从0开始,覆盖掉当前的文本,文末自然会多出来一些字符串(如果替换前的字符串比替换后的字符串少,则没有问题。例如: str(text).replace("https://at.alicdn.com/t","https://at.alicdn.com/t/assets/font"))。因此在读取文本后,需要立即将文本指针指向开始位置,再进行清理处理。
4、解决方案
#-*-coding:utf-8-*-
import os
filepath = "./dist/"
files = os.listdir(filepath)
for file in files:
if ".css" in file :
with open(filepath+file,'r+', encoding='UTF-8') as f:
# 读取文件 此时文件指针指到文件结尾
text = f.read()
# 重置文件指针为文件开头位置
f.seek(0)
# 清空文件
f.truncate()
# 替换字符串
text = str(text).replace("https://at.alicdn.com/t","assets/font")
# 将替换后的字符串写入
f.write(text)
# 关闭
f.close()