草庐IT

Python 数字类型之 int float

小小程序员ol 2023-03-31 原文

数字常量

  • 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内的任意数字 

有关Python 数字类型之 int float的更多相关文章

  1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  2. ruby - Infinity 和 NaN 的类型是什么? - 2

    我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串

  3. ruby - 检查方法参数的类型 - 2

    我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)

  4. ruby - Ruby 有 `Pair` 数据类型吗? - 2

    有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳

  5. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  6. ruby-on-rails - 在 Rails 开发环境中为 .ogv 文件设置 Mime 类型 - 2

    我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain

  7. Python 相当于 Perl/Ruby ||= - 2

    这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。

  8. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  9. 区块链之加解密算法&数字证书 - 2

    目录一.加解密算法数字签名对称加密DES(DataEncryptionStandard)3DES(TripleDES)AES(AdvancedEncryptionStandard)RSA加密法DSA(DigitalSignatureAlgorithm)ECC(EllipticCurvesCryptography)非对称加密签名与加密过程非对称加密的应用对称加密与非对称加密的结合二.数字证书图解一.加解密算法加密简单而言就是通过一种算法将明文信息转换成密文信息,信息的的接收方能够通过密钥对密文信息进行解密获得明文信息的过程。根据加解密的密钥是否相同,算法可以分为对称加密、非对称加密、对称加密和非

  10. 华为OD机试用Python实现 -【明明的随机数】 2023Q1A - 2

    华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o

随机推荐