Python字符串處理及實(shí)現(xiàn)字符串拼接的示例解析
Python字符串處理示例解析
一、字符串的"七十二變":創(chuàng)建與切片
Python字符串就像靈活的積木,支持多種創(chuàng)建方式:
# 單雙引號(hào)通用 msg = "Hello 數(shù)據(jù)科學(xué)家!" path = r'C:\new_folder' # 原始字符串避免轉(zhuǎn)義 # 切片操作 [start:end:step] text = "Python超實(shí)用" print(text[2:5]) # tho print(text[::-1]) # 用實(shí)超nohtyP
二、文本拼接的3把利器
- 加號(hào)拼接:簡(jiǎn)單少量文本
- join()方法:高效連接列表
- f-string:Python 3.6+首選
names = ["張偉", "李娜", "王陽(yáng)"]
# 傳統(tǒng)方式(性能低)
full_str = names[0] + "," + names[1] + "," + names[2]
# 高效方式
print(",".join(names)) # 張偉,李娜,王陽(yáng)
# 現(xiàn)代方式(推薦)
print(f"獲獎(jiǎng)?wù)撸簕names[0]}、{names[1]}、{names[2]}")三、切割與重組:split()和join()
這對(duì)黃金搭檔處理結(jié)構(gòu)化文本:
# 拆分CSV數(shù)據(jù)
csv_data = "ID,Name,Salary\n101,張三,15000"
rows = csv_data.split('\n')
for row in rows:
cols = row.split(',')
print(cols)
# 重組URL路徑
folders = ['img','2024','logo.png']
print('/'.join(folders)) # img/2024/logo.png四、精準(zhǔn)定位:查找替換技巧
- find():返回首次出現(xiàn)位置
- replace():全局替換內(nèi)容
- in關(guān)鍵字:快速存在性檢測(cè)
log = "ERROR: File not found [code:404]"
# 定位關(guān)鍵信息
print(log.find("404")) # 28
print("ERROR" in log) # True
# 敏感信息脫敏
secure_log = log.replace("404", "XXX")
print(secure_log) # ERROR: File not found [code:XXX]五、格式化輸出:三種高階玩法
告別混亂拼接:
# 1. %格式化(經(jīng)典)
print("溫度:%.1f°C" % 23.456) # 溫度:23.5°C
# 2. str.format()(靈活)
print("坐標(biāo):({x},{y})".format(x=120, y=89))
# 3. f-string(推薦)
name = "Alice"
print(f"歡迎{name.upper()}!積分:{1000*1.2:.0f}")六、清洗標(biāo)準(zhǔn)化:大小寫(xiě)與空白處理
數(shù)據(jù)清洗必備四件套:
raw_text = " Python數(shù)據(jù)分析 \t\n"
# 去空格
clean_text = raw_text.strip()
print(clean_text) # "Python數(shù)據(jù)分析"
# 大小寫(xiě)轉(zhuǎn)換
print(clean_text.upper()) # PYTHON數(shù)據(jù)分析
print(clean_text.lower()) # python數(shù)據(jù)分析
# 首字母大寫(xiě)
print("hello world".title()) # Hello World七、終極武器:完整數(shù)據(jù)處理模板
def clean_text_data(text):
"""文本清洗標(biāo)準(zhǔn)化流程"""
# 1. 去除首尾空白
text = text.strip()
# 2. 轉(zhuǎn)換為小寫(xiě)
text = text.lower()
# 3. 替換特殊字符
text = text.replace('$', 'USD').replace('¥', 'CNY')
# 4. 分割重組
words = text.split()
return ' '.join(words[:5]) # 保留前5個(gè)詞
raw_data = " $19.99 限時(shí)優(yōu)惠 買(mǎi)一送一 "
print(clean_text_data(raw_data))
# 輸出:usd19.99 限時(shí)優(yōu)惠 買(mǎi)一送一python中7種方法實(shí)現(xiàn)字符串的拼接
1.直接通過(guò)(+)操作符拼接
>>> 'Hello' + ' ' + 'World' + '!' 'Hello World!'
使用這種方式進(jìn)行字符串連接的操作效率低下,因?yàn)閜ython中使用 + 拼接兩個(gè)字符串時(shí)會(huì)生成一個(gè)新的字符串,生成新的字符串就需要重新申請(qǐng)內(nèi)存,當(dāng)拼接字符串較多時(shí)自然會(huì)影響效率。
2.通過(guò)str.join()方法拼接
>>> strlist = ['Hello', ' ', 'World', '!'] >>> ''.join(strlist) 'Hello World!'
這種方式一般常使用在將集合轉(zhuǎn)化為字符串,''.join()其中''可以是空字符,也可以是任意其他字符,當(dāng)是任意其他字符時(shí),集合中字符串會(huì)被該字符隔開(kāi)。
3.通過(guò)str.format()方法拼接
>>> '{} {}!'.format('Hello', 'World')
'Hello World!'通過(guò)這種方式拼接字符串需要注意的是字符串中{}的數(shù)量要和format方法參數(shù)數(shù)量一致,否則會(huì)報(bào)錯(cuò)。
4.通過(guò)(%)操作符拼接
>>> '%s %s!' % ('Hello', 'World')
'Hello World!'這種方式與str.format()使用方式基本一致。
5.通過(guò)()多行拼接
>>> ( ... 'Hello' ... ' ' ... 'World' ... '!' ... ) 'Hello World!'
python遇到未閉合的小括號(hào),自動(dòng)將多行拼接為一行。
6.通過(guò)string模塊中的Template對(duì)象拼接
>>> from string import Template
>>> s = Template('${s1} ${s2}!')
>>> s.safe_substitute(s1='Hello',s2='World')
'Hello World!'Template的實(shí)現(xiàn)方式是首先通過(guò)Template初始化一個(gè)字符串。這些字符串中包含了一個(gè)個(gè)key。通過(guò)調(diào)用substitute或safe_subsititute,將key值與方法中傳遞過(guò)來(lái)的參數(shù)對(duì)應(yīng)上,從而實(shí)現(xiàn)在指定的位置導(dǎo)入字符串。這種方式的好處是不需要擔(dān)心參數(shù)不一致引發(fā)異常,如:
>>> from string import Template
>>> s = Template('${s1} ${s2} ${s3}!')
>>> s.safe_substitute(s1='Hello',s2='World')
'Hello World ${s3}!'7.通過(guò)F-strings拼接
在python3.6.2版本中,PEP 498 提出一種新型字符串格式化機(jī)制,被稱為“字符串插值”或者更常見(jiàn)的一種稱呼是F-strings,F(xiàn)-strings提供了一種明確且方便的方式將python表達(dá)式嵌入到字符串中來(lái)進(jìn)行格式化:
>>> s1 = 'Hello'
>>> s2 = 'World'
>>> f'{s1} {s2}!'
'Hello World!'在F-strings中我們也可以執(zhí)行函數(shù):
#學(xué)習(xí)中遇到問(wèn)題沒(méi)人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流群:153708845
>>> def power(x):
... return x*x
...
>>> x = 5
>>> f'{x} * {x} = {power(x)}'
'5 * 5 = 25'而且F-strings的運(yùn)行速度很快,比%-string和str.format()這兩種格式化方法都快得多。
到此這篇關(guān)于Python字符串處理示例解析的文章就介紹到這了,更多相關(guān)Python字符串處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
windows下python模擬鼠標(biāo)點(diǎn)擊和鍵盤(pán)輸示例
這篇文章主要介紹了windows下python模擬鼠標(biāo)點(diǎn)擊和鍵盤(pán)輸示例,需要的朋友可以參考下2014-02-02
Python中猜拳游戲與猜篩子游戲的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于Python中猜拳游戲與猜篩子游戲的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
用Python中的字典來(lái)處理索引統(tǒng)計(jì)的方法
這篇文章主要介紹了用Python中的字典來(lái)處理索引統(tǒng)計(jì)的方法,字典的使用是Python學(xué)習(xí)當(dāng)中的基礎(chǔ)知識(shí),本文則是相關(guān)的一個(gè)小實(shí)踐,需要的朋友可以參考下2015-05-05
Python中文分詞工具之結(jié)巴分詞用法實(shí)例總結(jié)【經(jīng)典案例】
這篇文章主要介紹了Python中文分詞工具之結(jié)巴分詞用法,結(jié)合實(shí)例形式總結(jié)分析了Python針對(duì)中文文件的讀取與分詞操作過(guò)程中遇到的問(wèn)題與解決方法,需要的朋友可以參考下2017-04-04
Python 爬蟲(chóng)圖片簡(jiǎn)單實(shí)現(xiàn)
這篇文章主要介紹了Python 爬蟲(chóng)圖片簡(jiǎn)單實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2017-06-06
pytest用例執(zhí)行順序和跳過(guò)執(zhí)行詳解
本文主要介紹了pytest用例執(zhí)行順序和跳過(guò)執(zhí)行詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
Python socket實(shí)現(xiàn)多對(duì)多全雙工通信的方法
今天小編就為大家分享一篇Python socket實(shí)現(xiàn)多對(duì)多全雙工通信的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-02-02
python 順時(shí)針打印矩陣的超簡(jiǎn)潔代碼
今天小編就為大家分享一篇python 順時(shí)針打印矩陣的超簡(jiǎn)潔代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11

