博客
关于我
【Python入门与进阶】数据类型 (一)数字类型
阅读量:796 次
发布时间:2019-03-25

本文共 1566 字,大约阅读时间需要 5 分钟。

数据类型在编程中扮演着重要角色,直接关系到变量占用的内存空间和性能表现。在Python中,变量并不需要事先声明类型,但每种数据类型仍然对应不同的内存大小,这种特性决定了我们在程序设计时需要注意数据类型的选择和使用。

数据类型概述

Python的数据类型种类繁多,但我们主要关注数字类型的应用。常见的数字类型包括:

  • 整数(int):可以处理很大的数值,且Python3中整数没有大小限制。
  • 浮点数(float):用于存储小数值,如1.23、3.14。
  • 布尔值(bool):只能是True或False。

除上述基础类型外,还有一些高级数据类型:

  • 列表(list):用于存储可变长度的序列。
  • 元组(tuple):与列表类似,但不可变。
  • 字典(dict):用于存储键值对。
  • 集合(set):用于存储唯一元素。

数字类型的分类

在数字类型中,Python将数值划分为三类:

  • 整数

    • 在Python中,所有整数都使用int类型表示。
    • Python3的int类型支持任意精度,能够处理非常大的数值。例如:
      a = 10b = 20c = 999999999999999999999999999999999999999999999 ** 100d = -100
    • Python会自动为整数分配内存空间。
    • 整数运算不会造成精度问题。
  • 浮点数

    • 在Python中,所有浮点数都使用float类型表示。例如:
      c = 1.23d = 4.56
    • 浮点运算可能会产生精度问题。例如:
      c = 0.1 + 0.2print(c)  # 输出: 0.30000000000000004
    • 这种精度问题通常可以通过将浮点数转换为整数来解决。例如:
      money_pixel = 0.1 + 0.2  # 0.30000000000000004money_cent = int(money_pixel * 100)
  • 复数

    • 复数在Python中也有自己的类型,用于处理复杂数值。例如:
      z = complex(3, 4)print(z)  # 输出: (3+4j)
  • 数字类型的注意事项

  • 分隔符写法

    • 对于大数值,可以使用下划线作为分隔符,提升可读性。例如:
      value = 123_456_789
    • 这种写法在Python3中是有效的。
  • 不同进制的数字表示

    • Python支持多种进制的数字表示:
      • 二进制:以0b开头。
        binary_num = 0b1010  # 表示十进制的10
      • 八进制:以0o开头。
        octal_num = 0o12  # 表示十进制的10
      • 十六进制:以0x开头。
        hex_num = 0x1a  # 表示十进制的26

    -Hex的表示方式在日常编程中较少使用,但对调试和内存转换等场景有其优势。

  • 浮点运算精度问题--numerical operations with floating points can lead to precision errors. For example:

    c = 0.1 + 0.2  # 输出为0.30000000000000004
    • 在涉及金融计算或精确值统计时,建议将浮点数转换为整数存储。例如:
      money_pixel = 0.1 + 0.2  # 0.30000000000000004money_cent = int(money_pixel * 100)
  • 总结

    在编写Python程序时,正确选择和使用数据类型是非常重要的。了解不同数据类型的特点和限制,可以帮助我们更好地优化程序性能并避免潜在的错误。例如:

    • 对于大整数,可以直接使用int类型,无需担心数值溢出问题。
    • 对于浮点数,应谨记其运算可能存在的精度问题,并根据实际需求进行适当的类型转换。
    • 对于不同进制的数字表示,仅仅在调试或特定场景下使用,使代码更易读和直观。

    转载地址:http://udsyk.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
    查看>>