Python 數字類型之 int float

来源:https://www.cnblogs.com/python1111/archive/2023/03/31/17276547.html
-Advertisement-
Play Games

數字常量 int: 一般的整數, long: 長整型,2.x版本需在數字後加 “L” 或 “l” ,表示長整型 如 100000000L; python3.x 版本後不分長整型,統一為int,不可加 “L” 或 “l” float: 浮點數,1.0 也為浮點數,float 可強制轉換為 int,取整 ...


數字常量

  • int:  一般的整數,

  • long: 長整型,2.x版本需在數字後加 “L” 或 “l” ,表示長整型 如 100000000L; python3.x 版本後不分長整型,統一為int,不可加 “L” 或 “l”

  • float: 浮點數,1.0 也為浮點數,float 可強制轉換為 int,取整;

print(type(1234))
print(type(-24))
print(type(0))
print(type(2147483647))      # 為int
print(type(2147483648))      # >=2^31 為long    Python2.x ; Python3.x long 和 int 合併為 int
i = 1l                       # Python2.x 表示long,Python3 會報錯
print(i,type(i))
print(type(i))
print(type(1e+1))            # e表示法為浮點型
print(int(1e+20))            # 強制轉換為int
print(int(1e+30))            # 超長精度丟失
print(type(1.0))             # 小數表示為float
print(int(1.999))            # int()強制轉換為int 會把float取整

數字計算

加減乘數運算

a=1
b=2
c=2.0
print(a+b)
print(type(a+b))
print(a-c)          # 輸出 -1.0
print(type(a+c))    # 有浮點型加入,即自動轉換為 float
print(a*b)
print(type(a*b))    # 兩個整數相乘,仍為整數型
print(type(a*c))    # 有浮點型加入,即自動轉換為 float
print(a/b)
print(type(a/b))
print(b/a)
print(type(b/a))    # 除法運算,即使整除,結果仍為 float 類型

備註: print(1/0) 除數為0會報錯,而不是返回 NaN;一定要 註意 除數為0時的異常判斷;如需處理 NaN,需 from decimal import *

Decimal numbers include special values such as NaN which stands for “Not a number”, positive and negative Infinity, and -0

取餘運算、指數冪運算、取絕對值、四捨五入

print(3%2)                # 通常就做整數間的取餘運算
print(type(3%2))
print(type(3.0%2))        # 不建議浮點型取餘
print(2.1%2)              # 雖然float也可運算取餘,但結果帶精度,此結果為0.10000000000000009
print(3**2)               # ** 表示做次方運算,即冪運算
print(type(3**2))         # 整數的整數次冪仍為整數
print(2**-2)
print(type(2**-2))
print(1**-2)
print(type(1**-2))        # 負數次冪均為 float
print(4**0.5)
print(type(4**0.5))       # 非整數次冪均為 float
print(pow(2,3))           # 指數冪的另一表示法
print(abs(-1))            # 取絕對值
print(round(3.5))         # 四捨五入取整
print(round(3.49))        # 四捨五入取整
print(round(3.49,1))      # 可加一參數,表示取小數點後幾位四捨五入,如上結果為 3.5
print(round(3.04,1))

數字比較

比較運算符 == != > >= < <=

a = 1
b = 1.0
print(a==b)            # 數值的比較 返回 True

進位數

2進位數以 0b 開頭表示,8進位數以 0o 開頭表示(零和小寫o),16進位數以 0x 開頭表示;bin() 會以二進位輸出形式

a = 0b11100                # 2進位數  0b 開頭
b = 0o34                   # 8進位數  0o 開頭
c = 0x1c                   # 16進位數 0x開頭
print(a,b,c)
print(bin(2))              # bin()表示以二進位輸出

位運算

同很多語言一樣,Python的位運算符包括 << >> & | ~ ^

print(bin(0b110<<2))          # 左移2位
print(bin(0b110>>1))          # 右移1位
print(0&0,0&1,1&0,1&1)        # & 與運算
print(0|0,0|1,1|0,1|1)        # | 或運算
print(0^0,0^1,1^0,1^1)        # ^ 異或運算
print(bin(~0b11))             # ~ 非運算,有符號數的取反

Math 模塊

複雜的數學計算需導入數學模塊,即 import math ; 僅列出 math 模塊中一些常用的常量、函數等;具體要用時參閱官方幫助文檔。

import math
print(math.e)                       # 數學常量e
print(math.pi)                      # 數學常量pi
print(math.ceil(3.00001))           # 向上取整
print(math.floor(3.99999))          # 向下取整
print(math.sqrt(9))                 # 平方根 math.sqrt(x) == x**0.5  同樣返回 float 類型
print(math.exp(1))                  # exp(n)  math.e的n次方
print(math.log(math.e))             # 即Ln運算 即以自然常數e (2.71828......)為底數的對數
print(math.log(16,2))               # 以2為底,16的對數
print(math.log(1,10))               # 以10為底,1的對數
print(math.degrees(math.pi))        # Converts angle x from radians to degrees.
print(math.radians(60))             # Converts angle x from degrees to radians.
print(math.sin(math.radians(30)))   # 精度丟失
print(math.cos(math.pi/3))			#小編創建了一個Python學習交流群:725638078

Random 模塊

random 模塊可產生多種隨機數;這裡僅介紹 randint:產生範圍內的隨機整數;若需其他隨機數方法,具體要用時參閱官方幫助文檔。

random.randint(a, b) 
Return a random integer N such that a <= N <= b.
from random import randint
for i in range(1,11):            # 表示做十次迴圈
    print(randint(1,10))         # 輸出1到10內的任意數字 

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Spring Spring為簡化開發而生,讓程式員只關心核心業務的實現,儘可能的不在關註非業務邏輯代碼(事務控制,安全日誌等)。 1,Spring八大模塊 這八大模塊組成了Spring 1.1 Spring Core模塊 這是Spring框架的最基礎的部分,它提供了依賴註入(DependencyIn ...
  • React Native 備忘清單 適合初學者的綜合 React Native 備忘清單,在開始 React Native 之前需要先掌握 react 庫入門,為開發人員分享快速參考備忘單。 React Native (簡稱RN)是Facebook於2015年4月開源的跨平臺移動應用開發框架,是Fa ...
  • React 備忘清單 IT寶庫整理適合初學者入門的React開發速查備忘清單,為開發人員分享快速參考備忘單。 React是用於構建用戶界面的JavaScript庫,起源於Facebook的內部項目,該公司對市場上所有 JavaScript MVC框架都不滿意,決定自行開發一套,用於架設Instagr ...
  • 一、延遲計算 RDD 代表的是分散式數據形態,因此,RDD 到 RDD 之間的轉換,本質上是數據形態上的轉換(Transformations) 在 RDD 的編程模型中,一共有兩種運算元,Transformations 類運算元和 Actions 類運算元。開發者需要使用 Transformations ...
  • 一 回顧trait使用 https://blog.csdn.net/bushuwei/article/details/103514174發現之前本人說明很模糊,自己居然不知道為什麼其實這裡的$c,就是class B再次回顧邏輯 二 分析 self和static區別說的沒毛病 Trait基類use t ...
  • 一、函數的定義 可以分為以下兩種: 1、函數聲明和函數定義分離 這種方法將函數聲明和函數定義分開,通常在頭文件中先聲明函數原型,然後在源文件中實現函數定義。 例如,頭文件 example.h 中聲明瞭一個函數 add: #ifndef EXAMPLE_H #define EXAMPLE_H int ...
  • 一.scoket基本介紹 1.scoket簡介(以下是來自chatgpt回答) 1)Socket(套接字)是電腦網路中用於描述主機之間通信的一種機制。它定義了一種標準的介面, 使得應用程式可以利用網路傳輸層提供的服務(如TCP或UDP)進行通信。 2)Socket的作用是在網路應用程式之間提供數據 ...
  • if __name__ == "__main__" 也就是說執行當前文件,不調用模塊的時候__name__=__main__ 調用模塊的時候,測試如下: 1、新建 test01.py 文件測試代碼如下 print("這條消息來自test01") def func(): print('hello, w ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...