sqlserver concat 字符串位数不够左侧补0_一文搞懂Python字符串格式化
生活随笔
收集整理的這篇文章主要介紹了
sqlserver concat 字符串位数不够左侧补0_一文搞懂Python字符串格式化
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
字符串格式化有兩種方式:百分號方式、format方式。百分號方式比較老,從Python2.6引入了format這個格式化字符串的方法, 目前兩者共存。
一、百分號方式
1、%s 字符串
string = "hello"# %s打印時結果是helloprint("字符串=%s" % string) # output: string=hello# %2s意思是字符串長度為2,當原字符串的長度超過2時,按原長度打印,所以%2s的打印結果還是helloprint("字符串=%2s" % string) # output: string=hello# %7s意思是字符串長度為7,當原字符串的長度小于7時,在原字符串左側補空格,# 所以%7s的打印結果是 helloprint("字符串=%7s" % string) # output: string= hello# %-7s意思是字符串長度為7,當原字符串的長度小于7時,在原字符串右側補空格,# 所以%-7s的打印結果是 helloprint("字符串=%-7s!" % string) # output: string=hello !# %.2s意思是截取字符串的前2個字符,所以%.2s的打印結果是heprint("字符串=%.2s" % string) # output: string=he# %.7s意思是截取字符串的前7個字符,當原字符串長度小于7時,即是字符串本身,# 所以%.7s的打印結果是helloprint("字符串=%.7s" % string) # output: string=hello# %a.bs這種格式是上面兩種格式的綜合,首先根據小數點后面的數b截取字符串,# 當截取的字符串長度小于a時,還需要在其左側補空格print("字符串=%7.2s" % string) # output: string= heprint("字符串=%2.7s" % string) # output: string=helloprint("字符串=%10.7s" % string) # output: string= hello# 還可以用%*.*s來表示精度,兩個*的值分別在后面小括號的前兩位數值指定print("字符串=%*.*s" % (7, 2,string)) # output: string= he2、%d 整型
num = 14# %d打印時結果是14print("字符串=%d" % num) # output: num=14# %1d意思是打印結果為1位整數,當整數的位數超過1位時,按整數原值打印,所以%1d的打印結果還是14print("字符串=%1d" % num) # output: num=14# %3d意思是打印結果為3位整數,當整數的位數不夠3位時,在整數左側補空格,所以%3d的打印結果是 14print("字符串=%3d" % num) # output: num= 14# %-3d意思是打印結果為3位整數,當整數的位數不夠3位時,在整數右側補空格,所以%3d的打印結果是14_print("字符串=%-3d" % num) # output: num=14_# %05d意思是打印結果為5位整數,當整數的位數不夠5位時,在整數左側補0,所以%05d的打印結果是00014print("字符串=%05d" % num) # output: num=00014# %.3d小數點后面的3意思是打印結果為3位整數,# 當整數的位數不夠3位時,在整數左側補0,所以%.3d的打印結果是014print("字符串=%.3d" % num) # output: num=014# %.0003d小數點后面的0003和3一樣,都表示3,意思是打印結果為3位整數,# 當整數的位數不夠3位時,在整數左側補0,所以%.3d的打印結果還是014print("字符串=%.0003d" % num) # output: num=014# %5.3d是兩種補齊方式的綜合,當整數的位數不夠3時,先在左側補0,還是不夠5位時,再在左側補空格,# 規則就是補0優先,最終的長度選數值較大的那個,所以%5.3d的打印結果還是 014print("字符串=%5.3d" % num) # output: num= 014# %05.3d是兩種補齊方式的綜合,當整數的位數不夠3時,先在左側補0,還是不夠5位時,# 由于是05,再在左側補0,最終的長度選數值較大的那個,所以%05.3d的打印結果還是00014print("字符串=%05.3d" % num) # output: num=00014# 還可以用%*.*d來表示精度,兩個*的值分別在后面小括號的前兩位數值指定# 如下,不過這種方式4就失去補0的功能,只能補空格,只有小數點后面的3才能補0print("字符串=%*.*d" % (4, 3, num)) # output: num= 0143、%f 浮點型
import math# %a.bf,a表示浮點數的打印長度,b表示浮點數小數點后面的精度# 只是%f時表示原值,默認是小數點后5位數print("PI=%f" % math.pi) # output: PI=3.141593# 只是%9f時,表示打印長度9位數,小數點也占一位,不夠左側補空格print("PI=%9f" % math.pi) # output: PI=_3.141593# 只有.沒有后面的數字時,表示去掉小數輸出整數,03表示不夠3位數左側補0print("PI=%03.f" % math.pi) # output: PI=003# %6.3f表示小數點后面精確到3位,總長度6位數,包括小數點,不夠左側補空格print("PI=%6.3f" % math.pi) # output: PI=_3.142# %-6.3f表示小數點后面精確到3位,總長度6位數,包括小數點,不夠右側補空格print("PI=%-6.3f" % math.pi) # output: PI=3.142_# 還可以用%*.*f來表示精度,兩個*的值分別在后面小括號的前兩位數值指定# 如下,不過這種方式6就失去補0的功能,只能補空格print("PI=%*.*f" % (6, 3, math.pi)) # output: PI=_3.142二、format方式
1、通過位置
#通過位置print('輸出:{0},{1}'.format('優惠券','http://1668s.com') )print('輸出:{},{}'.format('博客','http://hi-laoz.com'))print('輸出:{1},{0},{1}'.format('優惠券','http://1668s.com'))字符串的format函數可以接受不限個參數,位置可以不按順序,可以不用或者用多次,不過2.6不能為空{},2.7才可以。
2、通過關鍵字參數
print('{name},{url}'.format(url='http://1668s.com',name='優惠券'))3、通過下標
p=['博客','http://hi-laoz.com']print('輸出:{0[0]},{0[1]}'.format(p))list和tuple可以通過“打散”成普通參數給函數,而dict可以打散成關鍵字參數給函數。所以可以輕松的傳個list/tuple/dict給format函數。非常靈活。
4、格式限定符
它有著豐富的的“格式限定符”(語法是{}中帶:號),比如:
填充與對齊
填充常跟對齊一起使用
^、分別是居中、左對齊、右對齊,后面帶寬度
:號后面帶填充的字符,只能是一個字符,不指定的話默認是用空格填充
比如
print('{:>8}'.format('189'))print('{:0>8}'.format('189'))print( '{:a>8}'.format('189'))5、精度與類型f
精度常跟類型f一起使用
print( '{:.2f}'.format(3.14159))其中.2表示長度為2的精度,f表示float類型。
6、其他類型
主要就是進制了,b、d、o、x分別是二進制、十進制、八進制、十六進制。
print('17的二進制:','{:b}'.format(17)) #二進制print('17的十進制:','{:d}'.format(17)) #十進制print('17的八進制:','{:o}'.format(17)) #八進制print('十的十六進制:','{:x}'.format(17)) #十六進制用,號還能用來做金額的千位分隔符。
print('{:,}'.format(1234567890))總結
以上是生活随笔為你收集整理的sqlserver concat 字符串位数不够左侧补0_一文搞懂Python字符串格式化的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python selenium webd
- 下一篇: python伪装浏览器https_pyt