栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

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

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

使用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’xe6x88x91’3
gbkb’xcexd2’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,你学废了吗?

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/870573.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号