无穷大正整数 python_python模块:数字处理

http://

blog.csdn.net/pipisorry/article/details/37055183

python数字处理简介

数字类型

python没有unsighed int:The Python int is an abstraction of an integer value, not a direct access to a fixed-byte-size integer.

不过int还是当成sighed int处理的?如0b10000取反~0b10000是-0b10001,虽然前面是用负号表示的,但是和c语言取反后的值是一样一样的,只是表示的很奇怪。

python不同的进制二进制    0b101,

以数字0和字母b打头的表示二进制数 如果出现大于等于2的数 会抛出SyntaxError异常,

八进制    0711,

以数字0打头的数字表示八进制数 如果出现大于等于8的数 会抛出SyntaxError异常,

十进制    123,

正常显示 不能出现字母,

十六进制  0x15,

以数字0和字幕x打头的表示十六进制数 可以出现0-9和abcdef或ABCDEF出现其他数值会抛出SyntaxError异常,

在交互式解释器环境中.python会自动的将不同的进制自动转换为十进制,进行运算.,

>>> 0b101 + 0711 + 123 + 0x15,

606,

不同的进制之间可以运用内置函数进行转换     int(str, base)      ==> int,

bin(num)            ==> str,

oct(num)            ==> str,

hex(num)           ==> str,

int(str, base) 可以讲字符串转换为整型数,base为相应的进制,

base的范围是2~32 还可以为0,当base=0时,会自动尝试合适的进制,

base如果不给,缺省情况下会吧字符串向10进制转换,,

这时如果字符串中有字母则会抛出ValueError异常,

>>> bin(5),

'0b101',

>>> int('0x210', 0),

528,

>>> int('0x210', 16),

528,

python最大整数

它是由Python的正整数类型所支持的最大整数。

python的最大整数:sys.maxsize   (py3)   sys.maxint    (py2)[py3中无定义]

usually 2**31 - 1 on a 32-bit platform and 2**63 - 1 (=9223372036854775807) on a64-bit platform

最小整数:-sys.maxsize+1     -sys.maxint+1

python最大浮点数

sys.float_info:

>>> import sys

>>> sys.float_info

sys.floatinfo(max=1.7976931348623157e+308, max_exp=1024, max_10_exp=308, min=2.2

250738585072014e-308, min_exp=-1021, min_10_exp=-307, dig=15, mant_dig=53, epsil

on=2.2204460492503131e-16, radix=2, rounds=1)

>>> sys.float_info.max

1.7976931348623157e+308

如果这还不够大,总是有正无穷大:

>>> infinity = float("inf")

>>> infinity

inf

>>> infinity / 10000

inf

该long类型有无限的精度,所以只受限于你的内存大小。

python定义epsilon

epsilon

=

pow(e,

-

6)或者

1.0e-6

皮皮blog

python数字处理模块主要有math模块、decimal模块、

random模块等。

python数学运算和转换内置函数[

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一段 Python 代码,用于遍历指定路径中的所有目录,并可限制最大深度。以下是每一行代码的解释: 1. `import math import operator import os from pathlib import Path` :这一行代码导入了 `math`、`operator`、`os` 和 `Path` 模块,使得我们可以使用这些模块提供的函数和类。 2. `def walk_to_find_directories(` :这一行开始定义一个名为 `walk_to_find_directories` 的函数,并传入三个参数。 3. `path: str,` :指定路径的字符串类型参数,即要遍历的路径。 4. `depth: int = math.inf,` :深度的整数类型参数,用于控制遍历的最大深度,默认值为无穷(即不限制深度)。 5. `including_source_directoriy: bool = False` :一个布尔类型参数,指示是否包括源目录(即传入的路径本身),默认值为 `False`。 6. `):` :函数定义的结尾,表示函数开始执行。 7. `if including_source_directoriy:` :如果 `including_source_directoriy` 为 `True`,则执行以下代码。 8. `yield Path(path)` :通过 `yield` 关键字返回 `path` 参数构建的 `Path` 对象作为生成器的值。 9. `depth -= 1` :将 `depth` 参数减 1,为后续的递归遍历做准备。 10. `with os.scandir(path) as p:` :使用 `with` 语句创建一个上下文管理器,同时遍历指定路径下的所有文件和目录,并赋值给 `p`。 11. `p = list(p)` :将 `p` 转化为一个列表。 12. `p.sort(key=operator.attrgetter("name"))` :按照文件或目录名称进行排序,使用 `operator.attrgetter` 函数实现属性获取。 13. `for entry in p:` :循环读取列表 `p` 中的每一个元素,即遍历文件和目录。 14. `if entry.is_dir():` :如果当前元素是目录。 15. `yield Path(entry.path)` :将当前元素创建的 `Path` 对象通过 `yield` 返回,作为生成器的值。 16. `if entry.is_dir() and depth > 0:` :如果当前元素是目录,并且深度仍可递归。 17. `yield from walk_to_find_directories(entry.path, depth)` :通过 `yield from` 关键字将递归遍历后生成的生成器添加到当前生成器中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值