python变量数据类型和运算符

目录
  • 1 数据类型
    • 1.1 基础类型
    • 1.2 类型判断
  • 2. 运算符和表达式
    • 2.1 算术运算符
    • 2.2 模运算说明
    • 2.3 数学函数
    • 2.4 随机函数
    • 2.5 赋值运算符
    • 2.6 关系运算
    • 2.7 逻辑运算
      • 2.7.1 逻辑与
      • 2.7.2 逻辑或
      • 2.7.3 逻辑非
    • 2.8 短路计算
    • 2.9 注意事项
    • 2.10 身份运算符
    • 2.11 成员运算符
    • 2.12 if-else表达式

1 数据类型

不同类型的变量可以进行的运算是不同的,所以必须理解变量的类型,python中数据类型可以分为:

内置类型:

  • 数值类型:整型int,浮点型float,复数(complex) 3+5j
  • str:字符串
  • bool:布尔值【True,False】
  • None:空值,表示变量没有确定的值
  • list:列表
  • tuple:元组
  • dict:字典
  • set:集合

自定义类型:

  • class :

1.1 基础类型

数值类型:

  • 整型(int): python3中只有int一种,可以表示整数,例如:10,-5,10000
  • 浮点型(float): 表示带小数点的实数,有两种表示法:
    • 小数表示: 1.9 .23
    • 科学计数法: 用e来表示10的指数,1e2就代表了100,注意e前面必须有数值,e后面必须为整数
  • 复数(complex):表示数学上的无理数,形如:a+bj
  • 布尔型(bool):表示事务的两种状态,男女、阴晴、亮暗等,它只有两个值:True,False
  • None:表示空对象,一般用于判断,不同于0和空字符
  • 字符串(str):在python中,用引号(单引号、双引号、三引号)表示字符串

字符串的表示:

# 用单引号表示: 'hello'
# 用双引号表示:"我用python"
# 用3个单引号表示:可以表示多行文本,例如:
'''伟大

祖国
'''
# 用3个双引号表示:可以表示多行文本,例如:
"""生死看淡,
不服就干"""

  • 转义字符:有些特殊字符无法从键盘输入,可以使用转义字符表示,另外,无论是单引号、双引号还是三引号字符串,其中引号是字符串界定符,引号并不是字符串的内容,那么如何在单引号字符串中表示一个单引号呢,这也可以使用转义字符表示。常见的转义字符

转义字符


描述


转义字符


描述


​\'​


表示一个普通字符单引号


\n


换行


​\"​


表示一个普通字符双引号


\r


回车


​\'''​


一个普通的三单引号


​\\​


一个普通的字符\


​\"""​


一个普通的三双引号


\a


响铃


\t


tab键


\b


回删一个字符

  • 字符串编码:计算机只能识别二进制,那么字符串如何存储到计算机里呢

计算机不能直接存储字符串,但我们可以将字符编码,例如用65表示大写字符A,66表示大写字符B....等这种表示方式就是美国类的ASCII码,只能表示127个字符,但对于美国人来说已经足够了。一但能用整数表示字符,我们可以很方便的把整数用二进制表示,那么字符串也就和容易存储到计算机了。
但还有很多其他国家的语言是不能用ASCII表示的,所有ISO组织就推出了unicode码,用来表示任何一种语言的字符,unicode码也称之为万国码,通用码,可以表示任何一种语言的任何一个字符。unicdoe码有多中表示方式,例如:utf-8、utf-16、utf-32等。一般使用较多的是utf-8,utf-8是一种变长的编码,表示一个字符可能用一个字节,也可能是三个字节
中文常用编码一般用GBK编码,用2个字节表示一个汉字

1.2 类型判断

我们可以使用type和isinstance来测试和判断数据类型

#type用法:
type(obj)
功能:返回obj的数据类型
参数:obj是你要测试变量或数值
示例:
age = 10
name = 'hello'
print(type(name),type(age))
#判断变量是否是指定类型
if type(age) is int:
print('是')
else:
print('否')

#isinstance用法:
isinstance(obj,typename)
功能:判断obj是否是指定类型,是返回True,否返回False
参数: objobj是你要判断的变量或数值
typename是指定数据类型,可以是int,float,str等。也可是一个
类型的元组,例如:(int,float)
示例:
age = 10
name = 'hello'
print(isinstance(age,int))
print(isinstance(name,(str,int)) #只要name是str或int的一种就返回True

if isinstance(age,int):
print('是')
else:
print('否')

#type和isinstance的区别
type判断基本类型是没问题的,但无法判断子类对象是父类的一种
isinstance可以判断子类对象是父类的一种
class A:
pass
class B(A):
pass

objA = A()
objB = B()

#输出否
if type(objB) is A:
print('是')
else:
print('否')
print(isinstance(objB,A)) #True

结论:优先使用isinstance

2. 运算符和表达式

在数学上为了计算结果,我们会写一些式子计算,例如:

30 + 5

这是数学中的计算式,python中为了计算也有类似的式子,叫表达式。在表达式中30和5称作操作数,+称之运算符。表达式的目的在于计算结果。表达式构成:

  • 最基本的表达式就是一些数值,变量、函数,例如: 3, a(变量) print(‘hello’)
  • 由基本表达式加上适当的运算符构成复杂的表达式: 3 + a

综合上述,所谓表达式就是由操作数和运算符组成䄦符合python语法的式子。要写表达式首先要学习运算符。关于运算符要知道两件事情

  • 计算顺序 : 是从左向右算还是从右向左算
  • 优先级 : 比如先乘除后加减

2.1 算术运算符

a = 20
b = 10

运算符


说明


示例


-


负号,取原数的相反数


a = 10 print(-a) #-10


+ - * /


加减乘除,同数学上一样


a + b = 30 a - b = 10 a * b = 200 a / b = 2


%


模运算,即求 a整除以b的余数


a % 10 = 0


//


整除


a // b = 2


**


对运算符进行指数(幂)计算


a ** b 表示20的10次方

2.2 模运算说明

  • 模运算的符号取决于第二个操作数(右操作数)
  • 模运算的计算公式:r = a % b = a - n * b,其中n是小于a/b的最大整数
  • 整除(//)运算如果有一个操作数是浮点数,结果是浮点数
  • 用途:判断奇偶、判断是否能够整除、最大公约数、水仙花数

2.3 数学函数


函数名


函数的说明


示例


abs


取绝对值


abs(-10)


pow(x,y)


x的y次方


pow(10,2)求10的平方


round(x,[n])


浮点数的4舍5入, n代表保留小数的位数


round(3.456)


max()


求给定参数的最大值


max(21,43,65,75,86,32,3,45)


min()


求给定参数的最小值


min(21,43,65,75,86,32,3,45)


math.ceil()


需要导入import math库 向上取整


math.ceil(18.1) #19


math.floor()


需要导入import math库 向下取整


math.floor(18.1) #18


math.sqrt


需要导入import math库 求平方根


math.sqrt(100)


​ ​python3.5.2中文帮助文档​​

   

2.4 随机函数

获取随机数,需要引入random库。

import random


函数名


函数说明


random.randrange(start,stop,step)


start 指定范围的起始值 包含本身,默认是0;stop 指定范围的结束值 不包含本身; step 步长,默认步长是1。该函数返回一个整数


random.randint(start,end)


返回[start end]之间的一个随机整数,start必须小于end


random.random()


返回一个[0.0,1.0)之间的随机小数

注意:

  • 优先级: ** >正负号 > // % * / > + -
  • 从左向右算
  • 在幂运算和一元运算符联合计算时,从右向左算,例如: -1 ** 2 = -1

2.5 赋值运算符

a = 5; b = 10; c = 20


运算符


说明


示例


=


简单赋值, 将b+c的结果赋给a


a = b +c #a=30


+=


a += b等价于 a = a +b


a = 15


-=


a -= b等价于 a = a - b


a = -5


*=


a *= b等价于 a = a * b


a = 50


/=


a /= b 等价于a = a / b


a = 0.5


%=


a %= b等价于a = a % b


a = 5


//=


a //= b等价于 a = a // b


a = 0


**=


a **= b等价于a = a ** b

 

注意:

  • 赋值运算符左边必须是变量
  • 从右向左算
  • 没有赋值表达式
  • 所有赋值运算符优先级相同,赋值运算符优先级非常低,仅高于成员运算符和身份运算符、逻辑运算符
  • 注意在复合赋值中
a = 2
b = 3
a *= b + 2 #等价于 a = a * (b + 2)
print(a) # a = 10

2.6 关系运算

关系运算就是比较运算,如果表达式成立,返回True,否则返回False。关系运算的结果是布尔值。


运算符


示例


说明


==


a == b


a和b值相等,结果是True,a和b值不相等结果为False


!=


a != b


a不等于b 结果为True,否则结果为True


>


a > b


a大于b结果为True,否则为False


>=


a >= b


a大于等于b结果为True,否则为False


<


a < b


a小于b结果为True,否则为False


<=


a <= b


a小于等于b结果为True,否则为False

注意

  • 优先级: 比较运算符优先级相同
  • 从左向右算
  • 可以这样算:​1 < a < 3​​ 等价于 a > 1 and a < 3

2.7 逻辑运算

逻辑运算符可以用于构造复杂条件。逻辑运算符包括:

  • 逻辑与 and 对应汉语的意思是“并且” 、 “同时”
  • 逻辑或 or 对应汉语意思为"或者"
  • 逻辑非 not 对应汉语意思为”相反“

在逻辑运算中,False、None、0、0.0、‘’(空字符串)被看做假(False),其它的看做真(True)

2.7.1 逻辑与


a


b


a and b



任意值


b的值



任意值


a的值

  • 表达式 a and b的值为: 如果a为真,结果为b的值,否则结果是a的值

2.7.2 逻辑或


a


b


a or b



任意值


a的值



任意值


b的值

  • 表达式a or b的值为:如果a为真结果为a的值,否则结果是b的值

2.7.3 逻辑非


a


not a



False



True

小结:a为真则表达式为False,否则表达式为True

2.8 短路计算

  • 对于逻辑与表达式 a and b,如果a为假,则不计算b
  • 对于逻辑或表达式 a or b ,如果a为真,则不计算b

2.9 注意事项

  • 优先级 not > and >or

2.10 身份运算符

is: 判断两个标识符是否引用自同一个实体【对象】,比较的是两个对象的id是否一样,如果相同为真,否则为假

is not:判断两个标识符是不是引用自不同的实体【对象】如果两个对象的id不同结果为真,否则为假

id()函数获取实体的id(地址)

注意:is和==的区别

  • is用于判断两个变量引用实体是否为同一个【id】
  • ==用于判断两个变量的值是否相同,但id不一定相同

2.11 成员运算符

主要应用在序列中

in:如果在指定的序列中找到指定的值,则返回True,否则返回False

not in:如果在指定的序列中未找到指定的值,则返回True,否则返回False

2.12 if-else表达式

表达式1 if 条件 else 表达式2,如果条件为真假结果是表达式1的值,否则结果是表达式2的值

到此这篇关于python变量数据类型和运算符的文章就介绍到这了,更多相关python 运算符内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python编程基础之运算符重载详解

    目录 学习目标 一.运算符重载 (一)概述 (二)加法运算重载符 1.概述 2.案例演示 总结 学习目标 1.掌握运算符重载 2.会定制对象字符串的形式 一.运算符重载 (一)概述 运算符重载是通过实现特定的方法使类的实例对象支持Python的各种内置操作 .例如:+运算符是类里提供的__add__这个函数,当调用+实现加法运算的时候,实际上是调用了__add__方法. 方法 说明 何时调用方法 __add__ 加法运算 对象加法:x+y,x+=y __sub__ 减法运算 对象减法:x-y,x

  • python字符串运算符详情

    知识点:字符串 在编程里,用的最多的就是字符串,字符串同时也是各类数据的中转站 ​字符串运算符:​ 编号 运算符类型 说明 1 + 字符串拼接 2 * 同一字符串多次输出 3 [] 通过下标获取字符串其中一个字符 ​代码如下:​ #!/usr/bin/python3 # -*- coding: utf-8 -*- import random # 字符串连接运算 myStr_a1='51' myStr_a2='cto' myStr=myStr_a1+myStr_a2 print('字符串:'+my

  • Python3实现自定义比较排序/运算符

    目录 自定义比较排序/运算符 1.cmp函数 2.重写类方法 Python3实现各种排序方法 自定义比较排序/运算符 Python3和Python2相比有挺多变化. 在Python2中可以直接写一个cmp函数作为参数传入sort来自定义排序,但是Python3取消了. 在这里总结一下Python3的自定义排序的两种写法,欢迎补充. 我们以二维空间中的点来作为待排序的数据结构,我们希望能先比较x后再比较y. class Pos:     def __init__(self, x = 0, y =

  • Python中的变量、运算符与流程控制

    目录 一.执行Python程序的两种方式 1.交互式 2.命令行式 二.变量 1.变量的组成 2.变量名的定义规范 3.定义变量的两种方式 4.常量 三.Python变量内存管理 1.引用计数 2.垃圾回收机制 3.小整数池 4.内存地址与数据类型 5.实例: 四.花式赋值 1. 链式赋值 2. 交叉赋值 3.多个变量赋值 五.与用户交互 六.格式化输出 1. 占位符(旧式字符串格式化,逐步淘汰) 2. format格式化 1.格式:<模板字符串>.format(<逗号分隔的参数>

  • python的运算符与表达式你真的了解吗

    目录 一.表达式 二.运算符 1.算术运算符 2.赋值运算符 3.比较运算符 4.逻辑运算符 5.成员关系运算 6.对象实例测试 7.位运算 8.一元运算 : 三.python运算符优先级 1.运算符优先级 2.计算顺序 总结 一.表达式 是由一个或多个操作数通过操作符组合而成 最简单的表达式仅包含一个字面值常量或变量 二.运算符 1.算术运算符 运算符 描述(变量a为10,变量b为21) 实例 + 加:两个对象相加 a+b 输出:31 - 减:得到负数或是一个数减去另一个数 a-b 输出:-1

  • Python中的变量和数据类型详情

    python是一门弱数据类型的语言,变量不需要声明即可使用,向变量赋值即定义变量,赋予的值的类型就是变量的类型,但变量也是有数据类型的,字符串'1'如果想参与数据计算,则需要使用int()函数来进行转换,使用type()函数可以查看变量的数据类型. 变量保存的是数据的内存地址的引用,python中变量分为不可修改变量和可修改变量,不可修改变量有int,float,str字符串,tuple元组等,可修改变量有list列表,dict字典,set集合等.当向函数中传递参数时,python一律传递值的引

  • 深入理解Python变量的数据类型和存储

      我们知道,python的变量是有类型的,对于python变量的几种数据类型,我们在写python时是必须要有一定的概念的.知道数据类型就要知道变量数据类型怎么存储,可是为什么python的变量不需要声明数据类型就可以直接赋值?变量如果有数据类型,那变量不是可以为任意数据类型?那真正的数据类型如int在内存存储的字节大小应该为多少?等等诸如一系列的问题让我提起了的兴趣,经过网上不断查找学习后,在此将我所了解到的内容在此做个总结归纳 一.变量的数据类型 1.什么是变量的数据类型   我们先捋一捋

  • Python中的变量及简单数据类型应用

    目录 一.变量 二.字符串 1.使用方法修改字符串的大小写 2.在字符串中添加空白 3.删除空白 三.数字 1.整数 2.浮点数 3.使用函数str()避免类型错误 四.Python 之禅 前言: 本文的主要内容是介绍Python中的变量命名规则和简单数据类型的应用,简单的数据类型包括字符串和数字等,文中还附有代码以及相应的运行结果辅助理解. 一.变量 变量的命名规则: 1.变量名只能包含字母.数字和下划线,且数字不能打头. 2.变量名不能包含空格,但可使用下划线来分隔其中的单词. 3.不要将P

  • python中and和or逻辑运算符的用法示例

    目录 一.概述 二.用法说明 (一)and 用法 (二)or 用法 三.两个集合and 和or操作的时候的问题 四.优先级问题(and > or) 附:python中if语句and和or用法总结 总结 一.概述 python中的逻辑操作符and 和or,也叫惰性求值,由于是惰性,只要确定了值就不往后解析代码了. 二.用法说明 (一)and 用法 文字说明: 第一种情况(判断语句): 从右往左解析,只要第一个是False,就是False,后面的就不需要运算了,整个都是错误的,无论后面是正确还是错误

  • python变量数据类型和运算符

    目录 1 数据类型 1.1 基础类型 1.2 类型判断 2. 运算符和表达式 2.1 算术运算符 2.2 模运算说明 2.3 数学函数 2.4 随机函数 2.5 赋值运算符 2.6 关系运算 2.7 逻辑运算 2.7.1 逻辑与 2.7.2 逻辑或 2.7.3 逻辑非 2.8 短路计算 2.9 注意事项 2.10 身份运算符 2.11 成员运算符 2.12 if-else表达式 1 数据类型 不同类型的变量可以进行的运算是不同的,所以必须理解变量的类型,python中数据类型可以分为: 内置类型

  • Java基本数据类型和运算符详解

    本文实例讲述了Java基本数据类型和运算符.分享给大家供大家参考,具体如下: 基本数据类型 Java 是一种强类型的语言,声明变量时必须指明数据类型.变量(variable)的值占据一定的内存空间.不同类型的变量占据不同的大小. Java中共有8种基本数据类型,包括4 种整型.2 种浮点型.1 种字符型.1 种布尔型,请见下表. Java基本数据类型 数据类型 说明 所占内存 举例 备注 byte 字节型 1 byte 3,127   short 短整型 2 bytes 3,32767   in

  • java数据类型和运算符的深入讲解

    一.整型变量 1.基本格式 int 变量名 = 初始值; 代码示例: public class CSDN { public static void main(String[] args) { int a=10; System.out.println(a); } } 2.java中的int是4个字节. 3.java中int的最大值和最小值 如果数大于0,则最高位为0,如果数小于0,则最高位为1.在判断数值范围时,不用考虑负数采用补码形式存储,因为补码和原码是一一对应的.当最高位是1,即为负数,后面

  • 解析python高级异常和运算符重载

    目录 一.高级异常 二.环境管理器 2.1.对象的属性管理函数 三.运算符重载 3.1.算术运算符的重载 四.反向算术运算符的重载 五.复合赋值算术运算符的重载 六.比较运算符的重载 七.位运算符重载 八.反向位运算符重载 九.复合赋值位运算符重载 十.一元运算符的重载 十一.in / not in 运算符的重载 十二.索引和切片运算符的重载 十三.slice 构造函数 一.高级异常 回顾异常相关的语句: try-except:用来捕获异常的通知 try-finally:用来做一定要做的事 re

  • JavaScript详细分析数据类型和运算符

    目录 一.js中的数据类型 1.数值型 2.字符串型 3.逻辑(布尔)型 4.空(null)值 5.未定义(undefined) 6.复合数据类型Object 二.JavaScript中的运算符 1.算数运算符 2.赋值运算符 3.比较运算符 4.逻辑运算符 一.js中的数据类型 1.JS是弱类型的脚本语言,所有的变量对象的数据类型的声明都是var . 2.变量声明时没有确定具体的数据类型,在变量赋值时确定变量具体的数据类型. 五种基本的数据类型 1.数值型 number整数和浮点数统称为数值.

  • python语法 之与用户交互和运算符

    目录 一 程序与用户交互 1.1.什么是与用户交互 1.2.为什么要与用户交互? 1.3.如何与用户交互 1.3.1 输入input: 1.3.2 输出print: 1.3.3 输出之格式化输出 二 基本运算符 2.1 算术运算符 2.2 比较运算符 2.3 赋值运算符 2.4 逻辑运算符 2.4.1 连续多个and 2.4.2 连续多个or 2.4.3 混用and.or.not 2.5 成员运算符 2.6 身份运算符 一 程序与用户交互 1.1.什么是与用户交互 用户交互就是人往计算机中inp

  • Python变量及数据类型用法原理汇总

    变量(Variable)可以看成一个小箱子,专门用来"盛装"程序中的数据.每个变量都拥有独一无二的名字,通过变量的名字就能找到变量中的数据. 从底层看,程序中的数据最终都要放到内存中,变量其实就是这块内存的名字. 1. Python变量的赋值 在编程语言中,将数据放入变量的过程叫做赋值(Assignment).每个变量在使用前都必须赋值,变量赋值以后,该变量才会被创建. Python 使用等号=作为赋值运算符,具体格式为: name = value # name 表示变量名,value

  • python的变量和运算符你都知道多少

    目录 python变量 1. 定义变量 (创建变量) 2.使用变量 3.重新给变量赋值 4. 同时定义多个变量 5.定义变量和重新赋值变量的原理 运算符 1. 数学运算符 2. 比较运算符: 3. 逻辑运算符: 4. 赋值运算符: 5.运算符的优先级 总结 python变量 1. 定义变量 (创建变量) 变量就是一种用来保存数据的容器,使用变量就是使用变量中保存的数据 语法:变量名 = 数据 1.变量名: 要求: 是标识符但不能是关键字 规范: 1. 见名知意(看到变量名就知道变量中保存的是什么

  • Python基础教程之输入输出和运算符

    在我们python中输入输出函数在程序中运用较为广泛,运算符常用于if判断的条件中,今天我来给大家讲解这两项概念. input输入和print输出 input()输入函数 从标准输入设备(一般指键盘)上读取一个字符串,末尾换行符会自动删除 所以我们想输出最后的数据,则需要进行类型转换 input("输入练习") danjia = int(input("请输入每一个多少钱\n")) zhongliang = int(input("请输入购买多少斤\n&quo

随机推荐