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处理后的文档:

Python格式化文本段落之textwrap库

读者可以自行测试,保证每行加上空格不多于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格。

Python格式化文本段落之textwrap库

当然,我们还可以选择特定的行进行缩进,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时,就缩进。否则便不缩进。运行之后,效果如下:

Python格式化文本段落之textwrap库

四、文本去缩进

既然有缩进文本,那么肯定就也有反向的操作去除缩进。下面,我们来通过函数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()函数只有需要操作的文本一个参数,效果如下:

Python格式化文本段落之textwrap库

这样,我们就实现了去除缩进。

五、截断文本

除了缩进与截断之外,我们还可以通过textwrap库截断文本进行操作。比如,我们常常看到某些资讯App简介会这样写“某某什么什么等等[…]”描述,这就是截取某文开头文字形成的结果字符串,textwrap.shorten正好可以完整实现,而且不会截断英文。


import textwrap

content = ""
with open('英文文档.txt', 'r', encoding='utf-8') as f:
   content = f.read()
print(textwrap.shorten(content, 100))

运行之后,效果如下:

Python格式化文本段落之textwrap库

来源:https://liyuanjinglyj.blog.csdn.net/article/details/115492265

标签:Python,textwrap,库,格式化
0
投稿

猜你喜欢

  • 讲解设计应用程序时避免阻塞的八个准则

    2009-01-04 14:16:00
  • python的pyecharts绘制各种图表详细(附代码)

    2021-12-29 16:51:13
  • python mac下安装虚拟环境的图文教程

    2021-11-02 23:35:21
  • python实现的config文件读写功能示例

    2021-10-11 07:28:04
  • Python 写小游戏吃金币+打乒乓+滑雪(附源码)

    2021-05-17 20:56:37
  • python删除文件示例分享

    2022-02-26 21:48:32
  • 如何使用Python在2秒内评估国际象棋位置详解

    2023-08-10 14:26:46
  • Pandas统计计数value_counts()的使用

    2023-11-24 10:28:46
  • urllib和BeautifulSoup爬取维基百科的词条简单实例

    2023-10-25 21:46:59
  • 帮你六步改善SQL Server安全规划全攻略

    2009-01-20 15:07:00
  • Python Json数据文件操作原理解析

    2022-10-27 19:00:32
  • Python手写回归树的实现

    2021-08-26 23:03:56
  • 利用Django-environ如何区分不同环境

    2022-01-10 10:52:24
  • 实现Python3数组旋转的3种算法实例

    2021-11-12 04:23:10
  • 深入浅出MySQL双向复制技术

    2009-03-25 15:40:00
  • asp使用 sql_dmo 给表添加索引

    2010-03-17 20:57:00
  • pyftplib中文乱码问题解决方案

    2023-11-10 11:34:07
  • Python中super关键字用法实例分析

    2023-12-08 06:11:46
  • list视图方式设计浅析

    2008-12-21 16:04:00
  • asp检测表单输入EMAIL合法性的函数

    2007-10-16 13:39:00
  • asp之家 网络编程 m.aspxhome.com