您好,登錄后才能下訂單哦!
這篇文章主要介紹了Python格式化文本段落之textwrap庫的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
前文是針對(duì)普通的字符串?dāng)?shù)據(jù)進(jìn)行處理。今天,我們要講解的textwrap庫,是對(duì)多文本進(jìn)行處理的庫。比如對(duì)于段落的縮進(jìn),填充,截取等,都可以通過textwrap庫進(jìn)行操作。
特別是自己編寫打印程序的時(shí)候,可以使用該庫進(jìn)行校正文檔非常便捷,大大的加快了文本格式的處理。
一般來說,一篇英文文檔在不考慮換行的情況下,默認(rèn)是填充整個(gè)文檔行才切換至下一行的?,F(xiàn)在,我們需要保證每行必須有且僅有50個(gè)字符怎么辦?
我們可以使用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))
運(yùn)行之后,分割線上下分別為原文檔與textwrap.fill處理后的文檔:
讀者可以自行測(cè)試,保證每行加上空格不多于50個(gè)字符,而且也沒有任何的縮進(jìn)效果。
既然通過textwrap.fill達(dá)不到文檔縮進(jìn)的效果。下面我們?cè)賮碚J(rèn)識(shí)一個(gè)新的函數(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ù)具有兩個(gè)參數(shù),一個(gè)是需要縮進(jìn)的字符串,另一個(gè)是匹配的縮進(jìn)字符。比如這里就是空了2格,那么字符串每行前面都會(huì)縮進(jìn)2格。
當(dāng)然,我們還可以選擇特定的行進(jìn)行縮進(jìn),textwrap.indent()函數(shù)還有第3個(gè)參數(shù)predicate,需要給它提供一個(gè)方法設(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)某行的字符串個(gè)數(shù)除2取余數(shù)等于0時(shí),就縮進(jìn)。否則便不縮進(jìn)。運(yùn)行之后,效果如下:
既然有縮進(jìn)文本,那么肯定就也有反向的操作去除縮進(jìn)。下面,我們來通過函數(shù)textwrap.dedent()來去除縮進(jìn)。
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ù)只有需要操作的文本一個(gè)參數(shù),效果如下:
這樣,我們就實(shí)現(xiàn)了去除縮進(jìn)。
除了縮進(jìn)與截?cái)嘀?,我們還可以通過textwrap庫截?cái)辔谋具M(jìn)行操作。比如,我們常常看到某些資訊App簡(jiǎn)介會(huì)這樣寫“某某什么什么等等[…]”描述,這就是截取某文開頭文字形成的結(jié)果字符串,textwrap.shorten正好可以完整實(shí)現(xiàn),而且不會(huì)截?cái)嘤⑽摹?/p>
import textwrap content = "" with open('英文文檔.txt', 'r', encoding='utf-8') as f: content = f.read() print(textwrap.shorten(content, 100))
運(yùn)行之后,效果如下:
1、簡(jiǎn)單易用,與C/C++、Java、C# 等傳統(tǒng)語言相比,Python對(duì)代碼格式的要求沒有那么嚴(yán)格;2、Python屬于開源的,所有人都可以看到源代碼,并且可以被移植在許多平臺(tái)上使用;3、Python面向?qū)ο?,能夠支持面向過程編程,也支持面向?qū)ο缶幊蹋?、Python是一種解釋性語言,Python寫的程序不需要編譯成二進(jìn)制代碼,可以直接從源代碼運(yùn)行程序;5、Python功能強(qiáng)大,擁有的模塊眾多,基本能夠?qū)崿F(xiàn)所有的常見功能。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Python格式化文本段落之textwrap庫的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。