欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python二分查找+字符串模板+textwrap模塊,

 更新時間:2022年05月16日 11:38:55   作者:? 夢想橡皮擦?  ?  
這篇文章主要介紹了Python二分查找+字符串模板+textwrap模塊,文章圍繞主題展開詳細內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下

前言:

這個系列的專欄是為了保持 Python 手感而創(chuàng)建的,也可以用來學習 Python,因為存在知識跨越難度,所以先學習滾雪球系列為佳。

二分查找

問題場景 在一個升序的數(shù)組中(其實就是一個只有整數(shù)的列表),查找一個目標數(shù)的下標,不存在返回 -1 。

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

編碼如下:

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

字符串模板

問題場景 + 拼接字符串會讓代碼變得難以閱讀,是否存在其它辦法可以將字符串進行格式化?

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

編碼如下:

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

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

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

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

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

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

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

textwrap 模塊

問題場景 Python中可以對文本,即字符串進行更加細致的操作,例如自動換行,填充字符。

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

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

  • dedent(text):移除 text 中每一行的任何相同前綴空白符;
  • fill(text, width=70, **kwargs):將單個段落包裝在 text 中,并返回包含已包裝段落的單個字符串,fill() 和 wrap() 方法類似,分割結(jié)果相同,但返回結(jié)果形式不同,它的作用就是在分割的片段之間添加 \n ,然后將其重新變成一個文本進行輸出;
  • indent(text, prefix, predicate=None):將 prefix 添加到 text 中選定行的開頭;
  • shorten(text, width, **kwargs):在 text 中截取給定 width 的字符;
  • wrap(text, width=70, **kwargs):將 text 中的單個段落(字符串)換行,每一行最多為 width 個字符長。返回輸出行列表,不帶最終換行符。

編碼如下 textwrap.wrap()

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

輸出結(jié)果如下:

textwrap.fill()

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

textwrap.dedent(text) 該方法可以移除不需要的前綴空格??梢杂脕硎谷柕淖址c顯示的左邊緣對齊,同時仍然以縮進的形式在源代碼中顯示。

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

運行結(jié)果如下:

textwrap.indent()

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

運行結(jié)果如下:

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

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

解決思路 通過判斷字符的前一字符是空格進行判斷。

編碼如下

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

用 “0” 填充字符串

問題場景 在字符串前面填充占位符 0 。

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

編碼時間

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

到此這篇關于Python二分查找+字符串模板+textwrap模塊,的文章就介紹到這了,更多相關Python 基礎內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Pytest運行及其控制臺輸出信息

    Pytest運行及其控制臺輸出信息

    這篇文章主要介紹了Pytest運行及其控制臺輸出信息,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • python中28種極坐標繪圖函數(shù)總結(jié)

    python中28種極坐標繪圖函數(shù)總結(jié)

    這篇文章主要為大家詳細介紹了python中28種極坐標繪圖函數(shù)的用法,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-09-09
  • Python實現(xiàn)簡單多線程任務隊列

    Python實現(xiàn)簡單多線程任務隊列

    本文給大家介紹的是使用很簡單的代碼實現(xiàn)的多線程任務隊列,給大家一個思路,希望對大家學習python能夠有所幫助
    2016-02-02
  • python3中的類繼承你真的了解嗎

    python3中的類繼承你真的了解嗎

    這篇文章主要為大家詳細介紹了python3中的類繼承,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • Pycharm安裝PyQt5的詳細教程

    Pycharm安裝PyQt5的詳細教程

    PyCharm 是一款功能強大的 Python 編輯器,具有跨平臺性,鑒于目前最新版 PyCharm 使用教程較少,為了節(jié)約時間,來介紹一下Pycharm安裝PyQt5的詳細教程,感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • Python I/O與進程的詳細講解

    Python I/O與進程的詳細講解

    今天小編就為大家分享一篇關于Python I/O與進程的詳細講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • Python命令行解析工具argparse模塊

    Python命令行解析工具argparse模塊

    這篇文章主要介紹了Python命令行解析工具argparse模塊,argparse模塊是一個python標準庫,它主要用于對用戶從客戶端輸入的命令進行解析,這使得編寫用戶友好的命令行接口變得非常容易,需要的朋友可以參考下
    2023-05-05
  • Python實現(xiàn)的插入排序算法原理與用法實例分析

    Python實現(xiàn)的插入排序算法原理與用法實例分析

    這篇文章主要介紹了Python實現(xiàn)的插入排序算法原理與用法,簡單描述了插入排序的原理,并結(jié)合實例形式分析了Python實現(xiàn)插入排序的相關操作技巧,需要的朋友可以參考下
    2017-11-11
  • django定期執(zhí)行任務(實例講解)

    django定期執(zhí)行任務(實例講解)

    下面小編就為大家?guī)硪黄猟jango定期執(zhí)行任務(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • Windows下搭建python開發(fā)環(huán)境詳細步驟

    Windows下搭建python開發(fā)環(huán)境詳細步驟

    這篇文章主要為大家詳細介紹了Windows下搭建python開發(fā)環(huán)境,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-05-05

最新評論