字串格式化
字串格式化其實就是字串的拼接,自定義將某些字串植入到主字串之中,這里介紹幾種常用的方式,
百分號占位
tmp = '你好 我是%s,我今天掙了%.2f元錢' value = ('小明',5.32567) str = tmp % value print(str)
列印結果:
你好 我是小明,我今天掙了5.33元錢
百分號是占位符,后面緊跟著元素型別,s就是string的意思,f就是float的意思,一般也只用得到這兩種,
格式化符號有一張表的,大概就是下面這樣

模板字串
from string import Template tmp1 = Template('你好 我是$name,我今天掙了$num元錢') str = tmp1.substitute(name="小紅",num="6") print(str)
列印結果:
你好 我是小紅,我今天掙了6元錢
format格式化
以前的老python必然有它遺留下來的寫法,但是目前大部分格式化字串的寫法還是以format方式為主流,
str = "{},{}還有{}".format("小明","小紅","小強") print(str)
列印結果:
小明,小紅還有小強
我們還可以在占位符中標記值的編號,編號從0開始,
str = "{2},{1}還有{4},你們三個里面只有{1}的學習最好".format("小明","小紅","小強","小芳","小黑") print(str)
列印結果:
小強,小紅還有小黑,你們三個里面只有小紅學習最好
我們仍然可以使用變數命名的方式:
str = "今天是{name}的{age}歲生日".format(name="小明",age=18) print(str)
列印結果:
今天是小明的18歲生日
如果你有興趣細扣的話,會發現format的用法有很多,各種稀奇古怪的替換方式和格式處理只有你想不到的,但是用到的時候都是小概率,所以就不過多描述了,
f字串
f字串是python3.6新加入的一種格式化字串的方式,對于新寫的代碼推薦使用這種方式來解決格式化的需求,
name = "小明" age = 18 str = f"今天是{name}的{age}歲生日" print(str)
列印結果:
今天是小明的18歲生日
可以看出,它其實就是變數植入,這種方式更易閱讀,
常用方法
字串居中 center()
這個方法通過在兩邊添加填充字符使得讓字串居中,默認填充的是空格
name = "我是小明" print(name) print(name.center(10))
列印結果:
我是小明
我是小明
上面的代碼讓字串填充到10個字符,除去字串本身占據4個字符,那么還需要填充6個,也就是左右各3個字符,
我們可以指定填充的字符:
name = "我是小明" print(name) print(name.center(10,'*'))
列印結果:
我是小明
***我是小明***
查找字串 find()
如果你想在一個字串中查找子字串,可以使用find方法,如果找到,會回傳子串所在的索引,如果沒找到,回傳-1
name = "我是小明" print(name.find('小明'))
列印結果:
2
你還可以指定查找范圍,find方法另有兩個選填引數,可以傳遞查找的開始索引與結束索引,
name = "我是小明" print(name.find('小明',0,3))
列印結果:
-1
需要注意的是,結束索引是不包含的,也就是說,我剛剛指定查找的是第0、第1、第2個索引,也就是“我是小”三個字,所以它回傳-1
大小寫轉換 upper、lower、title
轉大寫:
words = "abc" print(words.upper())
列印結果:
ABC
轉小寫:
words = "ABC" print(words.lower())
列印結果:
abc
以單詞為界限 首字母大寫其他小寫:
words = "my name is bob" print(words.title())
列印結果:
My Name Is Bob
打散字串 split()
字串打散后會回傳串列格式,不指定切割的字符的話,默認會在空白字符比如空格、tab符、換行符等地方進行切割,
words = "my name is bob" print(words.split())
列印結果:
['my', 'name', 'is', 'bob']
一般我們都會指定切割符:
words = "/usr/bin/env" print(words.split('/'))
列印結果:
['', 'usr', 'bin', 'env']
序列合并字串 join()
這個方法與split方法的作用完全相反,split把字串打散成序列,join可以把打散后的序列重新合并成原字串,
words = ['', 'usr', 'bin', 'env'] print('/'.join(words))
列印結果:
/usr/bin/env
去除左右空白 strip()
strip方法可以洗掉字串左右兩邊的空白字符,但是不包含中間的空白,
words = " my name is bob " print(words.strip())
列印結果:
my name is bob
你也可以傳入引數顯式指定要洗掉的字符:
words = "********my name is bob***" print(words.strip('*'))
列印結果:
my name is bob
如果你不想洗掉兩邊的,只想洗掉某一邊的,可以使用lstrip()和rsplip()方法分別洗掉左邊的字符和右邊的字符,
字串替換 replace()
words = "my name is bob, my name is bob" print(words.replace('bob','小明'))
列印結果:
my name is 小明, my name is 小明
三引號
會js的應該都知道js中有一個反引號的寫法,可以在其中隨意寫入多行文本,在python中可以用三個引號來做定界符,
words = ''' <li > <ul > <li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">宇宙</a></li> <li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">哲學</a></li> <li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">電子商務</a></li> <li> <a href="https://www.cnblogs.com/fengyumeng/p/xs3.html" target="mainFrame">互聯網</a></li> </ul> </li> ''' print(words)
列印結果:
<li >
<ul >
<li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">宇宙</a></li>
<li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">哲學</a></li>
<li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">電子商務</a></li>
<li> <a href="https://www.cnblogs.com/fengyumeng/p/xs3.html" target="mainFrame">互聯網</a></li>
</ul>
</li>
那如果我要在中間嵌入變數呢?
name = ('大學','中學','小學','幼兒園') words = ''' <li > <ul > <li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">%s</a></li> <li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">%s</a></li> <li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">%s</a></li> <li> <a href="https://www.cnblogs.com/fengyumeng/p/xs3.html" target="mainFrame">%s</a></li> </ul> </li> ''' print(words % name)
列印結果:
<li >
<ul >
<li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">大學</a></li>
<li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">中學</a></li>
<li><a href="https://www.cnblogs.com/fengyumeng/p/xs2.html" target="mainFrame">小學</a></li>
<li> <a href="https://www.cnblogs.com/fengyumeng/p/xs3.html" target="mainFrame">幼兒園</a></li>
</ul>
</li>
判斷是否滿足特定條件
純字母組成 isalpha()
words = 'abc' print(words.isalpha())
列印結果:
True
純數字組成 isdigit()
words = '123456' print(words.isdigit())
列印結果:
True
字母數字組成 isalnum()
檢測字串是否全部由字母和數字組成
words = 'abcd333' print(words.isalnum())
列印結果:
True
純字母或純數字或字母數字這三種都為true,除此之外都是false,哪怕有一個空格也是false,
words = 'abcd3 33' print(words.isalnum())
列印結果:
False
全大寫字母 isupper()
這方法只是針對字串里面的字母進行判斷,如果字串里面的字母是全部大寫,即為true,
words = ' ABCDEF123456' print(words.isupper())
列印結果:
True
全小寫字母 islower()
words = ' abc123456' print(words.islower())
列印結果:
True
結語
還有很多零零散散小概率使用的東西,也不知道怎么編排進來,也就算了,
所有序列的標準操作,包括索引、加法、乘法、切片、查找、長度、最大最小值都可以用在字串上,
但是字串是不可變的,所以所有的元素賦值和切片賦值都是不可用的,
另外一點,就是如果字串要加一個數字,那么你會發現程式會報錯,這種情況需要做型別轉換,可以使用str()方法將數字轉為字串,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/114461.html
標籤:Python
上一篇:生成器與迭代器筆記
