- 题记
- 效果
- 过程+代码
- 解释
使用python处理文件【对指定字数进行换行】 题记
书到用时方恨少,知识到用时才发现没有!
网上居然没有这样【如何将一整段文章按照指定字数进行换行】的教程,太可惜了!!!
千篇一律的文章,唉,太令人sick了!!!
也正是如此,才迫使我开始学习发明创造。。。🤣
效果前几天爬取的歌词,弄完之后才发现有些不合理。
毕竟如果作为歌词生成的话,应该有长又短才对,算了死马当活马医吧,假设每句歌词都一样长~
那么问题来了怎么样将这一段文字按照指定字数换行!!!
原来的样子
变换以后的样子
本来也就觉得没什么难度,但是网上竟然都只是基础教程,太辣鸡了!
算了,自己写吧!😫
path =".wangfenglyrics.txt"
path_new = ".wangfenglyrics_new.txt"
file_old = open(path,'r')
file_new = open(path_new,'w')
# 结束位置
end = file_old.seek(0,2)
for i in range(end//15):
# 定位下标
file_old.seek(i*45,0)
# 每15个字写入file_new.txt文件
file_new.write(file_old.read(15)+"\n")
解释
这里解释一下为什么seek(i*45,0)
,而不是seek(i*15,0)
例如中文 我 的不同编码方式
编码 | 我 | 个数 |
---|---|---|
utf-8 | b’\xe6\x88\x91’ | 3 |
gbk | b’\xce\xd2’ | 2 |
而seek
是移动是的uft-8字符
所以移动到下一个中文必须要移动三个字符
path = "./seek_ch.txt"
f = open(path,'w+')
f.write("我是中国人我骄傲!")
print(f.seek(3,0))
print(f.read(5))
而用英文时,就没有这个问题
path = "./seek_ch.txt"
f = open(path,'w+')
f.write("I am proud that I am a Chinese!")
print(f.seek(0,0))
print(f.read(10))
NOW,你学废了吗?
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)