溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python二分查找+字符串模板+textwrap模塊實(shí)例分析

發(fā)布時(shí)間:2022-05-16 14:25:10 來(lái)源:億速云 閱讀:164 作者:iii 欄目:開(kāi)發(fā)技術(shù)

今天小編給大家分享一下Python二分查找+字符串模板+textwrap模塊實(shí)例分析的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

二分查找

問(wèn)題場(chǎng)景 在一個(gè)升序的數(shù)組中(其實(shí)就是一個(gè)只有整數(shù)的列表),查找一個(gè)目標(biāo)數(shù)的下標(biāo),不存在返回 -1 。

解決思路 因?yàn)閿?shù)組是升序的,所以二分查找就能落地了 先取出數(shù)組中的中間值,與目標(biāo)數(shù)比較大小,確定一半的范圍 然后重復(fù)上述步驟不斷縮小范圍即可。

編碼如下:

def search(nums, start, end, target):
    if start > end:
        return -1
    # 獲取中間值
    mid = (start + end) // 2
    # 比較中間值與目標(biāo)數(shù)的大小關(guān)系
    if nums[mid] > target:  # 中值大于目標(biāo)數(shù)據(jù),目標(biāo)數(shù)在左側(cè)
        return search(nums, start, mid, target)
    if nums[mid] == target:  # 中值等于目標(biāo)數(shù)據(jù),返回
        return mid
    if nums[mid] < target:  # 中值小于目標(biāo)數(shù)據(jù),目標(biāo)數(shù)在右側(cè)
        return search(nums, mid, end, target)
if __name__ == '__main__':
    ret = search([1, 2, 3, 4], 0, 4, 1)
    print(ret)

字符串模板

問(wèn)題場(chǎng)景 + 拼接字符串會(huì)讓代碼變得難以閱讀,是否存在其它辦法可以將字符串進(jìn)行格式化?

解決思路 Python 字符串允許出現(xiàn)占位符,然后再通過(guò)特定的代碼將占位符替換掉。

編碼如下:

import string
tp1 = string.Template('你正在閱讀$name的博客')
tp2 = string.Template('你正在閱讀${name}的博客')
s1 = tp1.substitute(name="橡皮擦")
s2 = tp2.substitute(name="橡皮擦")
print(s1)
print(s2)

其中 $ 是占位符開(kāi)頭的特殊符號(hào),如果字符串本身也存在 $ 符號(hào),需要使用 $$ 代替。 字符串模板使用的是 string 模塊中的 Template 類,替換字符串需要調(diào)用對(duì)象的 substitute() 方法。 需要特別注意的是如果 substitute() 方法中的參數(shù)數(shù)量與模板中不一致,Python編譯器也不會(huì)拋出錯(cuò)誤。

import string
tp1 = string.Template('你正在閱讀$name的博客')
s1 = tp1.substitute(name="橡皮擦", age=18) # 參數(shù)不一致,不會(huì)出現(xiàn)錯(cuò)誤
print(s1)

但反之如果字符串模板中存在一個(gè)占位符,但是 substitute() 方法中沒(méi)有提供,就會(huì)拋出異常。

import string
tp1 = string.Template('你正在閱讀$name的博客')
tp2 = string.Template('你正在閱讀${name}$age的博客')
s1 = tp1.substitute(name="橡皮擦", age=18)  # 參數(shù)不一致,不會(huì)出現(xiàn)錯(cuò)誤
s2 = tp2.substitute(name="橡皮擦")  # 但是這樣確發(fā)生錯(cuò)誤
s3 = tp2.safe_substitute(name="橡皮擦")
print(s1)
print(s2)
print(s3)

解決上述問(wèn)題的辦法,就是使用 字符串模板類中提供的另一個(gè) safe_substitute() 方法,代碼如下

import string
tp1 = string.Template('你正在閱讀$name的博客')
tp2 = string.Template('你正在閱讀${name}$age的博客')
# s2 = tp2.substitute(name="橡皮擦")  # 但是這樣確發(fā)生錯(cuò)誤
s3 = tp2.safe_substitute(name="橡皮擦") # 不會(huì)報(bào)錯(cuò)
# print(s2)
print(s3)

textwrap 模塊

問(wèn)題場(chǎng)景 Python中可以對(duì)文本,即字符串進(jìn)行更加細(xì)致的操作,例如自動(dòng)換行,填充字符。

解決思路 使用 textwrap 模塊進(jìn)行操作。 首先使用 help() 函數(shù)查看該模塊具有哪些類與方法。

模塊內(nèi)具備類 TextWrapper(builtins.object) ,具備如下方法:

  • dedent(text):移除 text 中每一行的任何相同前綴空白符;

  • fill(text, width=70, **kwargs):將單個(gè)段落包裝在 text 中,并返回包含已包裝段落的單個(gè)字符串,fill() 和 wrap() 方法類似,分割結(jié)果相同,但返回結(jié)果形式不同,它的作用就是在分割的片段之間添加 \n ,然后將其重新變成一個(gè)文本進(jìn)行輸出;

  • indent(text, prefix, predicate=None):將 prefix 添加到 text 中選定行的開(kāi)頭;

  • shorten(text, width, **kwargs):在 text 中截取給定 width 的字符;

  • wrap(text, width=70, **kwargs):將 text 中的單個(gè)段落(字符串)換行,每一行最多為 width 個(gè)字符長(zhǎng)。返回輸出行列表,不帶最終換行符。

編碼如下 textwrap.wrap()

import textwrap
text = "你好, 我是橡皮擦  這是Python學(xué)習(xí)的第2天"
result = textwrap.wrap(text,10)
print(result)

輸出結(jié)果如下:

Python二分查找+字符串模板+textwrap模塊實(shí)例分析

textwrap.fill()

import textwrap
text = "你好, 我是橡皮擦  這是Python學(xué)習(xí)的第2天"
result = textwrap.fill(text,10)
print(result)

Python二分查找+字符串模板+textwrap模塊實(shí)例分析

textwrap.dedent(text) 該方法可以移除不需要的前綴空格??梢杂脕?lái)使三引號(hào)的字符串與顯示的左邊緣對(duì)齊,同時(shí)仍然以縮進(jìn)的形式在源代碼中顯示。

import textwrap
text = '''
    大家好
                    我是橡皮擦
    這是大家的Python博客'''
print(text)
print("*"*100)
print(textwrap.dedent(text))

運(yùn)行結(jié)果如下:

Python二分查找+字符串模板+textwrap模塊實(shí)例分析

textwrap.indent()

import textwrap
sample_text = '''
    你好,我是橡皮擦
    這是我的博客
    寫(xiě)作的內(nèi)容都是 Python
    希望得到你的關(guān)注
    '''
dedented_text = textwrap.dedent(sample_text)
final = textwrap.indent(dedented_text, '> ')
print(final)

運(yùn)行結(jié)果如下:

Python二分查找+字符串模板+textwrap模塊實(shí)例分析

按照空格統(tǒng)計(jì)詞組個(gè)數(shù)

問(wèn)題場(chǎng)景 一個(gè)段落,例如 "我 是 橡皮擦,這 是 大家 的 Python 博客",統(tǒng)計(jì)出有多少詞組。

解決思路 通過(guò)判斷字符的前一字符是空格進(jìn)行判斷。

編碼如下

class Ca:
    def phrase_count(self, p):
        c = 0 # 統(tǒng)計(jì)個(gè)數(shù)
        for i in range(len(p)):
            # 如果當(dāng)前字符不為空格并且不是第一位或者前一字符不是空格
            if p[i] != ' ' and (i == 0 or p[i - 1] == ' '):
                # 加1
                c += 1
        return c
if __name__ == '__main__':
    c = Ca()
    p = '我 是 橡皮擦,這 是 大家 的 Python 博客'
    print(f"詞組個(gè)數(shù)是:{c.phrase_count(p)}")

用 “0” 填充字符串

問(wèn)題場(chǎng)景 在字符串前面填充占位符 0 。

解決思路 使用 zfill() 方法返回指定長(zhǎng)度的字符串,原字符串右對(duì)齊,前面填充 0

編碼時(shí)間

str = "橡皮擦的博客"
print(str.zfill(20))
print(str.zfill(30))

Python二分查找+字符串模板+textwrap模塊實(shí)例分析

以上就是“Python二分查找+字符串模板+textwrap模塊實(shí)例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI