前面介紹了程序的流程控制,除此之外,你還需要在程序中表達數據,而為了表達數據,Python提供了各種數據類型。本文將介紹內置類型-Number,它用于表示數值類型,比如整數或實數。
本文將從以下幾個方面來介紹Python中的數值類型:
如何定義數值類型的變量
數值類型的轉換
數值類型的操作
如何定義數值類型的變量
Python內置了許多數值類型,這些類型中,常用的數值類型有int和float。你可以通過以下方式創建一個數值變量:
var1=1var2=10.0
var1是int類型的變量,它對應數學中的整數,它的范圍是(-inf, inf),即無窮大,下面的例子說明了這一點:
>>> a =100>>> type(a)>>> b =10**1000>>> b10000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000>>> type(b)
其中a和b均是整數,然而后者是一個非常大的整數。10**1000是指10的1000次方。也就是說Python中的int試圖在模擬數學中的整數。
var2是float類型的變量,它對應數學中的實數,你可以通過運行下面指令來查看它的范圍:
>>> sys.float_infosys.float_info(max=1.7976931348623157e+308, max_exp=1024, max_10_exp=308,min=2.2250738585072014e-308, min_exp=-1021, min_10_exp=-307, dig=15, mant_dig=53, epsilon=2.220446049250313e-16, radix=2, rounds=1)
以上輸出包含了max和min信息,如果你輸入一個比前者大的值,則輸出結果會變成inf,示例如下所示:
>>> af =1.7976931348623157e+309>>> afinf>>> af =1.7976931348623157e+308>>> af1.7976931348623157e+308
另外,float類型的變量是有精度限制的(最多16位),因此如果你需要使用更高精度的實數,那么可以考慮使用Python自帶的decimal模塊。
除了以上數字類型之外,還有一個比較常見的數值類型:bool,它常常用于條件語句,雖然它的輸出類型是bool,但是實際上它的內部數據是整型:
>>> baf = True>>> type(baf)>>> baf +23
以上就是Python中常用的數值類型,它們分別是int,float和bool,這些類型幾乎會出現在各種編程場景,因此也是必須掌握的。
數值類型的轉換
有時,你需要將數值類型轉換成其它類型,比如str,或者數值類型之間想要相互轉換。Python也提供了這些能力。
以下是數值類型轉換成str類型的示例:
>>> str1 = str(3)>>> str2 = str(3.14)>>> str1'3'>>> str2'3.14'>>> type(str1)
以下是str類型轉換成數值類型的示例:
>>> var1 = int('1')>>> var2=float('10.0')>>> var11>>> type(var1)
以下是float類型與int類型互轉的示例:
>>> var1 = int(10.02)>>> var2 = float(var1)>>> type(var1)>>> type(var2)
數值類型的操作
定義了數值類型的變量之后,接下來就可以對這些變量進行操作了,比如加,減,乘,除,取模等等。
以下是對2個數值類型進行相加的操作:
>>> var1 =1+2>>> var2 =1+2.0>>> type(var1)>>> type(var2)>>> var13>>> var23.0
需要注意的是,2個不同類型相加,其中范圍更小的類型會自動向范圍更大的類型轉換。比如上面的例子,var1可以由float來表示,因此該變量由int類型轉換成float類型,然后再與2.0相加。
也可以使用比較操作符來比較2個數值類型的變量,比如,下面的例子說明了這一點:
>>> a =2>>> b =3.0>>> is_a_great_than_b = a > b>>> print("a > b") if is_a_great_than_b else? print("a <= b")a <= b>>> type(is_a_great_than_b)
這句指令is_a_great_than_b = a > b比較了a和b,比較的結果是True。
除此之外,你還可以使用邏輯運算符來作用到數值類變量,具體例子如下所示:
>>> a =3>>> b =6.9>>> a_and_b = a and b>>> a_or_b = a or b>>> a_and_b6.9>>> type(a_and_b)>>> a_or_b3>>> type(a_or_b)
從上面的輸出結果可知,and和or運算符并不是簡單地輸出True或False,而是把原來的變量值返回。
結論
以上內容便是Python中數值類型的基礎,所以你必須學會如何定義和使用數值類型變量。數值類型的變量允許我們能夠以計算機的方式刻畫現實世界中的物體,比如我們想在計算機里定義一個人,那么這個人至少需要使用一個屬性,比如年齡(Age)來表示,在計算機里,我們可以定義一個int類型的變量,叫Age來表示一個人的年齡。除此之外,每個人都有對應的名字,那么在計算機里如何表示一個名字呢?這就是接下來要介紹的字符串類型。