使用python处理文件【对指定字数进行换行】

使用python处理文件【对指定字数进行换行】,第1张

文章目录
      • 题记
      • 效果
      • 过程+代码
      • 解释

使用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-8b’\xe6\x88\x91’3
gbkb’\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,你学废了吗?

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/884486.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-14
下一篇 2022-05-14

发表评论

登录后才能评论

评论列表(0条)

保存