主页 > 知识库 > Python格式化文本段落之textwrap库

Python格式化文本段落之textwrap库

热门标签:呼叫中心市场需求 语音系统 硅谷的囚徒呼叫中心 百度AI接口 企业做大做强 客户服务 Win7旗舰版 电话运营中心

一、前言

前文是针对普通的字符串数据进行处理。今天,我们要讲解的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))

运行之后,效果如下:

到此这篇关于Python格式化文本段落之textwrap库的文章就介绍到这了,更多相关Python textwrap库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • python编程开发之textwrap文本样式处理技巧
  • Python的文本常量与字符串模板之string库
  • Python中使用subprocess库创建附加进程
  • Python超简单容易上手的画图工具库推荐
  • python爬虫请求库httpx和parsel解析库的使用测评
  • Python高级文件操作之shutil库详解
  • Python超简单容易上手的画图工具库(适合新手)
  • python学习之panda数据分析核心支持库
  • Python基础之操作MySQL数据库
  • Python绘图库Matplotlib的基本用法
  • Python爬虫爬取爱奇艺电影片库首页的实例代码
  • Python Excel处理库openpyxl详解
  • python使用openpyxl库读写Excel表格的方法(增删改查操作)
  • Python time库的时间时钟处理
  • Python基础之常用库常用方法整理
  • python数据库批量插入数据的实现(executemany的使用)
  • Python爬虫之必备chardet库
  • python中requests库+xpath+lxml简单使用

标签:济南 山西 海南 崇左 山西 喀什 长沙 安康

巨人网络通讯声明:本文标题《Python格式化文本段落之textwrap库》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266