Python格式化文本段落之textwrap庫
一、前言
前文是針對普通的字符串?dāng)?shù)據(jù)進行處理。今天,我們要講解的textwrap庫,是對多文本進行處理的庫。比如對于段落的縮進,填充,截取等,都可以通過textwrap庫進行操作。
特別是自己編寫打印程序的時候,可以使用該庫進行校正文檔非常便捷,大大的加快了文本格式的處理。話不多說,我們來一步步學(xué)習(xí)textwrap庫。
二、切割文檔
一般來說,一篇英文文檔在不考慮換行的情況下,默認(rèn)是填充整個文檔行才切換至下一行的?,F(xiàn)在,我們需要保證每行必須有且僅有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達不到文檔縮進的效果。下面我們再來認(rèn)識一個新的函數(shù)textwrap.indent()函數(shù)。
import textwrap content = "" with open('英文文檔.txt', 'r', encoding='utf-8') as f: content = f.read() print(textwrap.indent(content," "))
textwrap.indent()函數(shù)具有兩個參數(shù),一個是需要縮進的字符串,另一個是匹配的縮進字符。比如這里就是空了2格,那么字符串每行前面都會縮進2格。
當(dāng)然,我們還可以選擇特定的行進行縮進,textwrap.indent()函數(shù)還有第3個參數(shù)predicate,需要給它提供一個方法設(shè)置特定的規(guī)則。具體代碼如下:
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)
這里,博主設(shè)置的規(guī)則是,當(dāng)某行的字符串個數(shù)除2取余數(shù)等于0時,就縮進。否則便不縮進。運行之后,效果如下:
四、文本去縮進
既然有縮進文本,那么肯定就也有反向的操作去除縮進。下面,我們來通過函數(shù)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()函數(shù)只有需要操作的文本一個參數(shù),效果如下:
這樣,我們就實現(xiàn)了去除縮進。
五、截斷文本
除了縮進與截斷之外,我們還可以通過textwrap庫截斷文本進行操作。比如,我們常常看到某些資訊App簡介會這樣寫“某某什么什么等等[…]”描述,這就是截取某文開頭文字形成的結(jié)果字符串,textwrap.shorten正好可以完整實現(xiàn),而且不會截斷英文。
import textwrap content = "" with open('英文文檔.txt', 'r', encoding='utf-8') as f: content = f.read() print(textwrap.shorten(content, 100))
運行之后,效果如下:
到此這篇關(guān)于Python格式化文本段落之textwrap庫的文章就介紹到這了,更多相關(guān)Python textwrap庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python編程開發(fā)之textwrap文本樣式處理技巧
- Python的文本常量與字符串模板之string庫
- Python中使用subprocess庫創(chuàng)建附加進程
- Python超簡單容易上手的畫圖工具庫推薦
- python爬蟲請求庫httpx和parsel解析庫的使用測評
- Python高級文件操作之shutil庫詳解
- Python超簡單容易上手的畫圖工具庫(適合新手)
- python學(xué)習(xí)之panda數(shù)據(jù)分析核心支持庫
- Python基礎(chǔ)之操作MySQL數(shù)據(jù)庫
- Python繪圖庫Matplotlib的基本用法
- Python爬蟲爬取愛奇藝電影片庫首頁的實例代碼
- Python Excel處理庫openpyxl詳解
- python使用openpyxl庫讀寫Excel表格的方法(增刪改查操作)
- Python time庫的時間時鐘處理
- Python基礎(chǔ)之常用庫常用方法整理
- python數(shù)據(jù)庫批量插入數(shù)據(jù)的實現(xiàn)(executemany的使用)
- Python爬蟲之必備chardet庫
- python中requests庫+xpath+lxml簡單使用
相關(guān)文章
python實現(xiàn)的jpg格式圖片修復(fù)代碼
這篇文章主要介紹了python實現(xiàn)的jpg格式圖片修復(fù)代碼,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2015-04-04pycharm配置安裝autopep8自動規(guī)范代碼的實現(xiàn)
這篇文章主要介紹了pycharm配置安裝autopep8自動規(guī)范代碼的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03python txt中的文件,逐行讀取并且每行賦值給變量問題
這篇文章主要介紹了python txt中的文件,逐行讀取并且每行賦值給變量問題,具有很好的參考價值,希望對大家有所幫助。2023-02-02python實戰(zhàn)項目scrapy管道學(xué)習(xí)爬取在行高手?jǐn)?shù)據(jù)
這篇文章主要為介紹了python實戰(zhàn)項目scrapy管道學(xué)習(xí)拿在行練手爬蟲項目,爬取在行高手?jǐn)?shù)據(jù),本篇博客的重點為scrapy管道pipelines的應(yīng)用,學(xué)習(xí)時請重點關(guān)注2021-11-11