Python格式化文本段落之textwrap库
作者:李元静 发布时间:2023-11-23 00:40:56
一、前言
前文是针对普通的字符串数据进行处理。今天,我们要讲解的textwrap库,是对多文本进行处理的库。比如对于段落的缩进,填充,截取等,都可以通过textwrap库进行操作。
特别是自己编写打印程序的时候,可以使用该库进行校正文档非常便捷,大大的加快了文本格式的处理。话不多说,我们来一步步学习textwrap库。
二、切割文档
一般来说,一篇英文文档在不考虑换行的情况下,默认是填充整个文档行才切换至下一行的。现在,我们需要保证每行必须有且仅有50个字符怎么办?
我们可以使用textwrap.fill方法,具体代码如下:
import textwrap
content = ""
with open('英文文档.txt', 'r', encoding='utf-8') as f:
content = f.read()
print(content)
print("----")
print(textwrap.fill(content, width=50))
运行之后,分割线上下分别为原文档与textwrap.fill处理后的文档:
读者可以自行测试,保证每行加上空格不多于50个字符,而且也没有任何的缩进效果。
三、文本缩进
既然通过textwrap.fill达不到文档缩进的效果。下面我们再来认识一个新的函数textwrap.indent()函数。
import textwrap
content = ""
with open('英文文档.txt', 'r', encoding='utf-8') as f:
content = f.read()
print(textwrap.indent(content," "))
textwrap.indent()函数具有两个参数,一个是需要缩进的字符串,另一个是匹配的缩进字符。比如这里就是空了2格,那么字符串每行前面都会缩进2格。
当然,我们还可以选择特定的行进行缩进,textwrap.indent()函数还有第3个参数predicate,需要给它提供一个方法设置特定的规则。具体代码如下:
import textwrap
def choice_line(line):
return len(line) % 2 == 0
content = ""
with open('英文文档.txt', 'r', encoding='utf-8') as f:
content = f.read()
indent_str = textwrap.indent(content, " ",predicate=choice_line)
print(indent_str)
这里,博主设置的规则是,当某行的字符串个数除2取余数等于0时,就缩进。否则便不缩进。运行之后,效果如下:
四、文本去缩进
既然有缩进文本,那么肯定就也有反向的操作去除缩进。下面,我们来通过函数textwrap.dedent()来去除缩进。
import textwrap
content = ""
with open('英文文档.txt', 'r', encoding='utf-8') as f:
content = f.read()
indent_str = textwrap.indent(content, " ")
print(textwrap.dedent(indent_str))
textwrap.dedent()函数只有需要操作的文本一个参数,效果如下:
这样,我们就实现了去除缩进。
五、截断文本
除了缩进与截断之外,我们还可以通过textwrap库截断文本进行操作。比如,我们常常看到某些资讯App简介会这样写“某某什么什么等等[…]”描述,这就是截取某文开头文字形成的结果字符串,textwrap.shorten正好可以完整实现,而且不会截断英文。
import textwrap
content = ""
with open('英文文档.txt', 'r', encoding='utf-8') as f:
content = f.read()
print(textwrap.shorten(content, 100))
运行之后,效果如下:
来源:https://liyuanjinglyj.blog.csdn.net/article/details/115492265
猜你喜欢
- 如何限制上传文件的大小?要限制上传大小,只需如下设置一个属性即可: &
- 前言Django提供了多种装饰器, 其中login_required可能是经常会使用到的。 这里介绍下四种使用此装饰器的办法。当然, 在使用
- 和网友们讨论了数组取交集的方法,下面是两个实现arr1=["1","5","6"
- 前言在Python中可迭代(Iterable)、迭代器(Iterator)和生成器(Generator)这几个概念是经常用到的,初学时对这几
- 最近和一程序员合作项目。弄的我头都大了~埋怨我的CSS命名看不懂~得按照他的来。结果我打开他的页面,看了看,从头第一个开始就是content
- 在用JS编写动画的时候,经常用会到布局转换,即在运动前将相对定位转为绝对定位,然后执行动画函数。下面给大家分享一个运用原生JS实现的布局转换
- 在做DHTML时,我们在某些情况下要用setAttribute(attri, value)方法定义元素的attribute。同时与getAt
- #!/usr/bin/env Pythonfrom __future__ import print_functionfrom collect
- 最近一直在用Vs2013调试编译opencv,意外发现一个超级赞的图片查看的插件, 超级方便易用的一个插件,直接以图片形式可视化了openc
- 先装 MYSQL 的 ODBC 驱动然后'connect to MySQL server&n
- 万维网联盟(W3C)发布了HTML 5规格说明书的草稿 ,这是自HTML 4在十多年前发布以来的第一个主要的修订版.在这期间,随着开发者逐渐
- rs.open sql,conn,A,B A: ADOPenforwardonly (=0) 只读,且当前数据记录只能向下移动。 ADOPe
- python help使用C:\Users\wusong>pythonPython 3.8.2rc1 (tags/v3.8.2rc1:
- 数据概况Fashion-mnist经典的MNIST数据集包含了大量的手写数字。十几年来,来自机器学习、机器视觉、人工智能、深度学习领域的研究
- 淘宝招聘的一个css题目:css样式控制div水平垂直居中方法;<!DOCTYPE html PUBLIC "-//W3C/
- JS在firefox中的兼容性问题,自己也经常遇到.此文是网上资料,不过时间较久不记得原址了...1. document.form.item
- 导读前面几章我们以经介绍了怎么批量对excel和ppt操作今天我们说说对word文档的批量操作应用python-docx允许您创建新文档以及
- ie的javascript失效了,不是设置的问题那么就可能是以下几点问题了~安装KAV可能会破坏系统的javascript关联,失javas
- test.asp 测试演示文件clsrsa.asp 实现rsa加密与解密的vbs类文件下面是代码:1. test.asp<%rem 文
- 最近接触了一些selenium模块的相关知识,觉得还挺有意思的,于是决定亲自尝试写一些爬虫程序来强化selenium模块(一定要多尝试、多动