%d、%f、字符串格式的方法%s、format和python3.6新特性f-string和類型注解


一、%s

# 1.位置參數的形式
msg = '我叫%s,今年%s,性別%s' % ('帥哥',18,'')
print(msg)  # 我叫帥哥,今年18,性別男

# 2.關鍵字參數的形式
msg = '我叫%(name)s,今年%(age)s,性別%(sex)s' % {"name": "帥哥", "age": 18, "sex": ""}
print(msg)  # 我叫帥哥,今年18,性別男
string = "hello"

# %s打印時結果是hello
print("string=%s" % string)  # output: string=hello

# %2s意思是字符串長度為2,當原字符串的長度超過2時,按原長度打印,所以%2s的打印結果還是hello
print("string=%2s" % string)  # output: string=hello

# %7s意思是字符串長度為7,當原字符串的長度小於7時,在原字符串左側補空格,
# 所以%7s的打印結果是  hello
print("string=%7s" % string)  # output: string=  hello

# %-7s意思是字符串長度為7,當原字符串的長度小於7時,在原字符串右側補空格,
# 所以%-7s的打印結果是  hello
print("string=%-7s!" % string)  # output: string=hello  !

# %.2s意思是截取字符串的前2個字符,所以%.2s的打印結果是he
print("string=%.2s" % string)  # output: string=he

# %.7s意思是截取字符串的前7個字符,當原字符串長度小於7時,即是字符串本身,
# 所以%.7s的打印結果是hello
print("string=%.7s" % string)  # output: string=hello

# %a.bs這種格式是上面兩種格式的綜合,首先根據小數點后面的數b截取字符串,
# 當截取的字符串長度小於a時,還需要在其左側補空格
print("string=%7.2s" % string)  # output: string=     he
print("string=%2.7s" % string)  # output: string=hello
print("string=%10.7s" % string)  # output: string=     hello

# 還可以用%*.*s來表示精度,兩個*的值分別在后面小括號的前兩位數值指定
print("string=%*.*s" % (7, 2, string))  # output: string=     he

 

二、%d

num = 14

# %d打印時結果是14
print("num=%d" % num)  # output: num=14

# %1d意思是打印結果為1位整數,當整數的位數超過1位時,按整數原值打印,所以%1d的打印結果還是14
print("num=%1d" % num)  # output: num=14

# %3d意思是打印結果為3位整數,當整數的位數不夠3位時,在整數左側補空格,所以%3d的打印結果是 14
print("num=%3d" % num)  # output: num= 14

# %-3d意思是打印結果為3位整數,當整數的位數不夠3位時,在整數右側補空格,所以%3d的打印結果是14_ (_代表空格,方便展示給你們看)
print("num=%-3d" % num)  # output: num=14_

# %05d意思是打印結果為5位整數,當整數的位數不夠5位時,在整數左側補0,所以%05d的打印結果是00014
print("num=%05d" % num)  # output: num=00014

# %.3d小數點后面的3意思是打印結果為3位整數,
# 當整數的位數不夠3位時,在整數左側補0,所以%.3d的打印結果是014
print("num=%.3d" % num)  # output: num=014

# %.0003d小數點后面的0003和3一樣,都表示3,意思是打印結果為3位整數,
# 當整數的位數不夠3位時,在整數左側補0,所以%.3d的打印結果還是014
print("num=%.0003d" % num)  # output: num=014

# %5.3d是兩種補齊方式的綜合,當整數的位數不夠3時,先在左側補0,還是不夠5位時,再在左側補空格,
# 規則就是補0優先,最終的長度選數值較大的那個,所以%5.3d的打印結果還是  014
print("num=%5.3d" % num)  # output: num=  014

# %05.3d是兩種補齊方式的綜合,當整數的位數不夠3時,先在左側補0,還是不夠5位時,
# 由於是05,再在左側補0,最終的長度選數值較大的那個,所以%05.3d的打印結果還是00014
print("num=%05.3d" % num)  # output: num=00014

# 還可以用%*.*d來表示精度,兩個*的值分別在后面小括號的前兩位數值指定
print("num=%*.*d" % (4, 3, num))  # output: num= 014

 

三、%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位數左側補0
print("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來表示精度,兩個*的值分別在后面小括號的前兩位數值指定
print("PI=%*.*f" % (6, 3, math.pi))  # output: PI=_3.142

 

四、format

# 三種方式:
# 第一種:按順序接收參數
s1 = '我叫{},今年{},性別{}'.format('帥哥','18','')
print(s1)   # 我叫帥哥,今年18,性別男


# 第二種:按索引接收參數
s2 = '我叫{0},今年{1},性別{2},我依然叫{0}'.format('帥哥', '18', '')
print(s2)  # 我叫帥哥,今年18,性別男,我依然叫帥哥


# 第三種:按關鍵字接收參數
s3 = '我叫{name},今年{age},性別{sex}'.format(age='18', name='帥哥', sex='')
print(s3)  # 我叫帥哥,今年18,性別男

 

三、f-string

1、介紹
f-string(formatted string literals):格式化字符串常量,是Python3.6新引入的一種字符串格式化方法,使格式化字符串的操作更加簡便。


2、語法
f'xxx' 或 F'xxx'  且以大括號 {} 表明被替換的字段,{}里面可以是字符串或者表達式


3、簡單替換字符串:{'字符串'}
name = '小白'
msg = f'我叫{name},今年{18}歲,性別{"男"}'
print(msg)  # 我叫小白,今年18歲,性別男
注意:若f使用的是單引號,那么里面的{}若是字符串則應該用雙引號,反之一樣


4、計算表達式:{表達式}
ret = f"1 add 2 is {1+2}"
print(ret)  # 1 add 2 is 3


5、lambda表達式:{(lambda表達式) (參數)}
注意:
lambda表達式的 : 會被f-string誤認為是表達式與格式描述符之間的分隔符,
為避免歧義,需要將lambda表達式置於括號 () 內:

func = f"my_add result:{(lambda x,y:x+y) (1,2)}"
print(func)  # my_add result:3

若不加括號則報錯:
func = f"my_add result:{lambda x,y:x+y (1,2)}"
print(func)


  File "<fstring>", line 1
    (lambda x,y)
               ^
SyntaxError: unexpected EOF while parsing


6、f-string用法很強大,這里只是寫出了一些常用的方法,感興趣可以自己去研究其他用法

 

五、類型注解

Python是一門動態語言,變量以及函數的參數是不區分類型。比如我們要實現一個數字相加的函數:
def my_add(x, y):
  return x + y
但是這樣的壞處是,別人不知道你要做的是數字相加的函數,別人輸入字符串,一樣是可以得到字符串的拼接的


於是 Python 3 提供了一個新的特性:
類型注解:
def my_add(x:int, y:int) -> int:
  return x + y

語法:
參數:類型   指定函數的參數類型
-> 類型    指定函數的返回值類型。


注意:Python 解釋器並不會因為這些注解而提供額外的校驗,
也就是說,這些類型注解加不加,對你的代碼來說沒有任何影響,我一樣可以輸入字符串的。

只是這么做的好處是:
1.讓別人看得更明白
2.當你輸入str和float 類型的參數時,雖然一樣不會報錯可以得出結果,但是IDE工具會有高亮提示
 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM