• Day02—Python的变量类型、变量命名、变量类型检查、变量类型转换、运算符


    Python3变量类型

    变量是存储在内存中的值,这就意味着在创建变量时会在内存中开辟一个空间。

    基于变量的数据类型,解释器会分配指定内存,并决定什么数据可以被存储在内存中。

    因此,变量可以指定不同的数据类型,这些变量可以存储整数,小数或字符。

    Python中的数据类型很多,而且也允许我们自定义新的数据类型,我们先介绍几种常用的数据类型:

    • 整型(int):Python中可以处理任意大小的整数(Python2.x中有int和long两种类型的整数,但这种区分对Python来说意义不大,因此在Python 3.x中整数只有int这一种了),而且支持二进制(如0b100,换算成十进制是4)、八进制(如0o100,换算成十进制是64)、十进制(100)和十六进制(0x100,换算成十进制是256)的表示法。
    • 浮点型(float):浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的,浮点数除了数学写法(如123.456)之外还支持科学计数法(如1.23456e2)。
    • 字符串型(String):字符串是以单引号或双引号括起来的任意文本,比如’hello’和"hello",字符串还有原始字符串表示法、字节字符串表示法、Unicode字符串表示法,而且可以书写成多行的形式(用三个单引号或三个双引号开头,三个单引号或三个双引号结尾)。
    • 布尔型:布尔值只有TrueFalse两种值,要么是True,要么是False,在Python中,可以直接用TrueFalse表示布尔值(请注意大小写),也可以通过布尔运算计算出来(例如3< 5会产生布尔值True,而2 == 1会产生布尔值False)。
    • 复数型(complex):形如3+5j,跟数学上的复数表示一样,唯一不同的是虚部的i换成了j。实际上,这个类型并不常用,大家了解一下就可以了。

    Python变量命名规范

    对于每个变量我们需要给它取一个名字,就如同我们每个人都有属于自己的响亮的名字一样。在Python中,变量命名需要遵循以下这些必须遵守硬性规则和强烈建议遵守的非硬性规则。

    硬性规则:

    1. 变量名由字母(广义的Unicode字符,不包括特殊字符)、数字和下划线构成,数字不能开头。
    2. 变量命名严格区分大小写(大写的a和小写的A是两个不同的变量)。
    3. 不要跟关键字(有特殊含义的单词,后面会讲到)和系统保留字(如函数、模块等的名字)冲突,如:print

    PEP 8要求:

    1. 用小写字母拼写,多个单词用下划线连接。
    2. 受保护的实例属性用单个下划线开头。
    3. 私有的实例属性用两个下划线开头。

    Tip:Python关键字keyword模块里。

    import keyword
    print(keyword.kwlist)
    
    • 1
    • 2
    ['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
    # 上面这些关键字都不能作为变量名。
    
    • 1
    • 2

    Python变量的使用

    # 使用变量保存数据并进行加减乘除运算
    a = 321
    b = 12
    print(a + b)    # 333
    print(a - b)    # 309
    print(a * b)    # 3852
    print(a / b)    # 26.75
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 变量类型检查

    在Python中可以使用type函数对变量的类型进行检查。

    # 使用type()检查变量的类型
    a = 100
    b = 12.345
    c = 1 + 5j
    d = 'hello, world'
    e = True
    print(type(a))    # 
    print(type(b))    # 
    print(type(c))    # 
    print(type(d))    # 
    print(type(e))    # 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 变量类型转换

    可以使用Python中内置的函数对变量类型进行转换。属于显式类型转换,强制转换。
    int():将一个数值或字符串转换成整数,可以指定进制。

    x = int(1)   # x 输出结果为 1
    y = int(2.8) # y 输出结果为 2
    z = int("3") # z 输出结果为 3
    
    • 1
    • 2
    • 3

    float():将一个字符串转换成浮点数。

    x = float(1)     # x 输出结果为 1.0
    y = float(2.8)   # y 输出结果为 2.8
    z = float("3")   # z 输出结果为 3.0
    w = float("4.2") # w 输出结果为 4.2
    
    • 1
    • 2
    • 3
    • 4

    str():将指定的对象转换成字符串形式,可以指定编码。

    x = str("s1") # x 输出结果为 's1'
    y = str(2)    # y 输出结果为 '2'
    z = str(3.0)  # z 输出结果为 '3.0'
    
    • 1
    • 2
    • 3

    chr():将整数转换成该编码对应的字符串(一个字符)。
    ord():将字符串(一个字符)转换成对应的编码(整数)。

    例:整型和字符串类型进行运算,就可以用强制类型转换来完成.

    num_int = 123
    num_str = "456"
    
    print("num_int 数据类型为:",type(num_int))
    print("类型转换前,num_str 数据类型为:",type(num_str))
    
    num_str = int(num_str)    # 强制转换为整型
    print("类型转换后,num_str 数据类型为:",type(num_str))
    
    num_sum = num_int + num_str
    
    print("num_int 与 num_str 相加结果为:",num_sum)
    print("sum 数据类型为:",type(num_sum))
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    输出结果为:

    num_int 数据类型为: <class 'int'>
    类型转换前,num_str 数据类型为: <class 'str'>
    类型转换后,num_str 数据类型为: <class 'int'>
    num_int 与 num_str 相加结果为: 579
    sum 数据类型为: <class 'int'>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    Python运算符

    • Python算术运算符

    运算符描述
    + - * /加、减、乘、除
    %取模 - 返回除法的余数
    **幂 - 返回x的y次幂
    //取整除 - 向下取接近商的整数
    • Python比较运算符

    运算符描述
    ==等于 - 比较对象是否相等
    !=不等于 - 比较两个对象是否不相等
    >大于 - 返回x是否大于y
    <小于 - 返回x是否小于y。所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。注意,这些变量名的大写。
    >=大于等于 - 返回x是否大于等于y。
    <=小于等于 - 返回x是否小于等于y。
    • Python逻辑运算符

    运算符逻辑表达式描述
    andx and y“与” - 如果 x 为 False,x and y 返回 x 的值,否则返回 y 的计算值。
    orx or y“或” - 如果 x 是 True,它返回 x 的值,否则它返回 y 的计算值。
    nonot x“非” - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。
    • Python成员运算符

    运算符描述实例
    in如果在指定的序列中找到值返回 True,否则返回 False。x 在 y 序列中 , 如果 x 在 y 序列中返回 True。
    not in如果在指定的序列中没有找到值返回 True,否则返回 False。x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。
    • Python身份运算符

    运算符描述实例
    isis 是判断两个标识符是不是引用自一个对象x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False
    is notis not 是判断两个标识符是不是引用自不同对象x is not y , 类似 id(x) != id(y)。如果引用的不是同一个对象则返回结果 True,否则返回 False。
    """
    比较运算符和逻辑运算符、成员运算符的使用
    """
    flag0 = 1 == 1
    flag1 = 3 > 2
    flag2 = 2 < 1
    flag3 = flag1 and flag2
    flag4 = flag1 or flag2
    flag5 = not (1 != 2)
    print('flag0 =', flag0)    # flag0 = True
    print('flag1 =', flag1)    # flag1 = True
    print('flag2 =', flag2)    # flag2 = False
    print('flag3 =', flag3)    # flag3 = False
    print('flag4 =', flag4)    # flag4 = True
    print('flag5 =', flag5)    # flag5 = False
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
  • 相关阅读:
    nginx实现灰度上线(InsCode AI 创作助手)
    生成树协议STP、RSTP、MSTP原理是什么?三者有啥区别?一文带你了解!
    软件测试(四)黑盒,白盒,灰盒测试
    高压放大器在金属材料静电悬浮过程中的应用
    matplotlib一点记录
    【LeetCode】No.75. Sort Colors -- Java Version
    第二章:C语言基础之数据类型+常量+变量+转义字符
    ldd用于打印程序或库文件所依赖的共享库列表
    go cpu、内存监控、性能分析:PProf
    设计模式之桥接模式
  • 原文地址:https://blog.csdn.net/weixin_39550080/article/details/127430580