Python中常用的有7种值(数据)的类型及type()语句的用法

news2024/7/6 17:41:26

目录

    • 0.Python中常用的有7种值(数据)的类型
      • Python中的数据类型主要有:```Number```(数字)、```Boolean```(布尔)、```String```(字符串)、```List```(列表)、```Tuple```(元组)、```Dictionary```(字典)、```Set```(集合)。
    • 1. ```type()```语句的使用方式
    • 2. ```isinstance()```判断一个变量的类型
    • 3.数据类型的转换

0.Python中常用的有7种值(数据)的类型

在这里插入图片描述
在这里插入图片描述
Python 中的每个值都有一个数据类型。
在 Python 编程中,一切(万物)皆对象,数据类型实际上是类,变量是这些类的实例(对象)。

Python中的数据类型主要有:Number(数字)、Boolean(布尔)、String(字符串)、List(列表)、Tuple(元组)、Dictionary(字典)、Set(集合)。

其中又分为可变数据类型和不可变数据类型,可变数据类型是指可以随着函数的执行发生变化,而不可变数据类型不可以改变

  1. 不可变数据类型(3个):Number(数字)、Boolean(布尔)、String(字符串)、Tuple(元组)
  2. 可变数据类型(4个):List(列表)、Dictionary(字典)、Set(集合)

1. type()语句的使用方式

  1. 类型:数字
  • int(整型)

  • float(浮点型)

  • complex(复数)

    Py3.x 去除了 long 类型,现在只有一种整型int,表示为长整型

print(type(111)) # 这是单行注释,整数可以是任何长度,只受到可用内存的限制。```
print(type(111.0)) #浮点数精确到 15 位小数。
print(type(4+3j)) #复数以 x + yj 的形式写成,其中 x 是实部,y 是虚部。
'''
这是多行注释,用三个单引号
'''
>>> i = 2 ** 500  # 2 的 500 次幂
>>> i
3273390607896141870013189696827599152216642046043064789483291368096133796404674554883270092325904157150886684127560071009217256545885393053328527589376
>>> 
>>> f = 0.12345678901234567890
>>> f
0.12345678901234568  # 值被截断
>>> 
>>> c = 5+6j
>>> c
(5+6j)
  1. 类型:布尔
print(type(True))

在这里插入图片描述

  1. 类型:字符串
    字符串是 Unicode 字符的序列。
    可以使用单引号('')或双引号("")来表示字符串,多行字符串可以使用三重引号 ‘’’ 或 “”" 来表示。
print(type("湖南"))

在这里插入图片描述

>>> s = 'Hello, Python!'  # 单引号
>>> s
'Hello, Python!'
>>> 
>>> s = "Hello, World!"  # 双引号
>>> s
'Hello, World!'
>>> 
>>> s = '''Hello,  # 三重单引号
... Python!'''
>>> s
'Hello,\nPython!'
>>> 
>>> s = """  # 三重双引号
... Hello,
... World!
... """
>>> s
'\nHello,\nWorld!\n'

字符串可以被索引和截取,截取的语法格式如下:

变量[头下标:尾下标]

索引值以 0 开始,-1 为从末尾的开始位置。

>>> s = "Hello, World!"
>>>
>>> s[4]  # 第五个字符
'o'
>>>
>>> s[7:10]  # 第八个开始到第十个的字符
'Wor'
>>>
>>> s[-4:-1]  # 倒数第四个开始到倒数第一个的字符
'rld'
>>> s[0:-1]  # 从第1个开始到倒数第一个的字符
''Hello, World''
>>> s[:-1]  # 从第1个开始到倒数第一个的字符(0可省略)
''Hello, World''
>>>
>>> s[5] = 'p'  # 生成错误,字符串是不可变的
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'str' object does not support item assignment

加号(+)是字符串的连接符, 星号(*) 表示复制当前字符串,紧跟的数字为复制的次数。

>>> s1 = "Hello,"
>>> s2 = " World!"
>>>
>>> s1 + s2  # 连接字符串
'Hello, World!'
>>>
>>> (s1 + s2) * 3  # 复制 3 次字符串
'Hello, World!Hello, World!Hello, World!'
  1. 类型:列表
    列表是有序的元素序列,它是 Python 中使用最频繁的数据类型,非常灵活。
    列表中元素的类型可以不同,支持数字、字符串,甚至可以包含列表(所谓的嵌套)。
    列表用[] 标识,内部元素用逗号分隔。
print(type([1,2,3,4,5,6,7]))

在这里插入图片描述
和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。

>>> l = [3, 2, 5, 4, 1]
>>> l
[3, 2, 5, 4, 1]  # 有序
>>> 
>>> l[2]  # 第三个元素
5
>>> 
>>> l[0:3] # 从第一个元素到第三个元素
[3, 2, 5]
>>> 
>>> l[3:] # 从第三个元素开始的所有元素
[4, 1]

列表是可变的,意思是说,列表中元素的值可以被改变。

>>> l = [1, 2, 3]
>>> l[2] = 5  # 将第三个元素 3 变为 5
>>> l
[1, 2, 5]
  1. 类型:元组
    元组与列表相同,也是有序序列,唯一的区别是元组是不可变的。
    元组适用于保护性的数据,通常比列表快,因为它不能动态更改。
    元组用() 标识,内部元素用逗号分隔。
print(type((1,2,3,4,5,6,7)))

在这里插入图片描述
元组也可以被索引和截取,但是不能被更改。

>>> t = (3, 2, 5, 4, 1)
>>> t
(3, 2, 5, 4, 1)  # 有序
>>> 
>>> t[1]  # 第二个元素
2
>>> 
>>> t[0:2] # 从第一个元素到第二个元素
(3, 2)
>>> 
>>> t[0] = 10  # 生成错误,元组是不可变的
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'tuple' object does not support item assignment

虽然元组中的元素不可变,但它可以包含可变的对象,例如:List(列表)。
构造一个空的或者包含一个元素的元组比较特殊,所以要采用一些额外的语法规则:

>>> tup1 = ()  # 空元组
>>> tup2 = (5, )  # 一个元素,需要在元素后添加逗号
  1. 类型:集合
    集合是一个无序不重复元素集。
    集合用 {} 标识,内部元素用逗号分隔。
    可以使用大括号 {} 或者 set() 函数创建集合,注意: 要创建一个空集合,必须使用 set() 而不是 {},因为 {} 用于创建一个空字典。
a={1,2,3,4,5,6,7}
print(type(a))

在这里插入图片描述
既然集合是无序的,那么索引就没有任何意义,也就是说,切片操作符 [] 不起作用。

>>> s = {"Java", "Python", "PHP"}
>>> s
{'PHP', 'Python', 'Java'}  # 无序
>>> 
>>> s[1]  # 生成错误,不支持索引
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'set' object does not support indexing

不重复,是指集合中相同的元素会被自动过滤掉,只保留一份。

>>> s = {"PHP", "Python", "Java", "Python", "PHP"}
>>> s
{'PHP', 'Python', 'Java'}  # 去重

除了去重之外,还常用于成员关系的测试。

>>> if ('Python' in s) :
...      print('Python 在集合中')
... else :
...      print('Python 不在集合中')
... 
Python 在集合中

集合之间也可执行运算,例如:并集、差集、交集。

>>> a = set('abcdefg')
>>> b = set('abghijk')
>>> 
>>> a
{'b', 'f', 'e', 'd', 'a', 'c', 'g'}
>>> b
{'b', 'k', 'h', 'i', 'j', 'a', 'g'}
>>> 
>>> a - b  # 差集
{'f', 'c', 'd', 'e'}
>>> 
>>> a | b  # 并集
{'b', 'k', 'f', 'h', 'i', 'e', 'j', 'd', 'a', 'c', 'g'}
>>> 
>>> a & b  # 交集
{'b', 'a', 'g'}
>>> 
>>> a ^ b  # 对称差 - 不同时存在的元素
{'e', 'c', 'k', 'f', 'h', 'i', 'j', 'd'}

对称差公式:A Δ B = (A − B) ∪(B − A)。也可表示为两个集合的并集减去它们的交集:A Δ B = (A ∪B) − (A ∩B)

  1. 类型:字典
    字典是键值对的无序集合。
    通常在有大量的数据时会使用,在检索数据时字典做了优化,必须知道要检索的 value 所对应的 key。
    字典用 {} 标识,其中的每个元素都以 key:value对的形式出现,key 和 value 可以是任何类型。
    注意: 字典中的 key 必须是唯一的。
a={'admin':'pwd'}
print(type(a))

在这里插入图片描述
可以用 key 来检索相应的 value,但相反则不行。

>>> d = {}  # 创建空字典
>>> d['name'] = 'Python'  # 增加新的键/值对
>>> d['site'] = 'www.python.org'
>>> 
>>> d
{'name': 'Python', 'site': 'www.python.org'}
>>> 
>>> d['site']  # 键为 'site' 的值
'www.python.org'
>>> 
>>> d['Python']  # 生成错误,不能用 value 检索 key
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
KeyError: 'Python'

字典有一些内置的函数,例如:keys()、values()、clear() 等。

>>> d.keys()  # 所有键
dict_keys(['name', 'site'])
>>> 
>>> d.values()  # 所有值
dict_values(['Python', 'www.python.org'])
>>> 
>>> d.clear()  # 清空字典
>>> d
{}

2. isinstance()判断一个变量的类型

可以使用type(变量名称)方法,返回变量的数据类型;2.isinstance(变量名称,数据类型),只能返回True或False

a=111
print(isinstance(a,int))

在这里插入图片描述

3.数据类型的转换

可以使用不同的类型转换函数来转换不同的数据类型,例如:int()float()str()等。
从 int 转换为 float:

>>> float(5)
5.0

从 float 到 int 的转换,值将会被截断(使其接近零):

>>> int(10.8)
10
>>> 
>>> int(-10.8)
-10

字符串的转换必须包含兼容的值:

>>> float('2.5')
2.5
>>> 
>>> str(25)
'25'
>>> 
>>> int('str')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: 'str'

甚至可以将一个序列转换为另一个序列:

>>> set([1, 2, 3])
{1, 2, 3}
>>> 
>>> tuple({4, 5, 6})
(4, 5, 6)
>>> 
>>> list('hello')
['h', 'e', 'l', 'l', 'o']

要转换为字典,每个元素必须是一对:

>>> dict([[1, 'value'], ['key', 2]])
{1: 'value', 'key': 2}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1878334.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

万字长文详解数据结构:树 | 第6章 | Java版大话数据结构 | 二叉树 | 哈夫曼树 | 二叉树遍历 | 构造二叉树 | LeetCode练习

&#x1f4cc;本篇分享的大话数据结构中&#x1f384;树&#x1f384;这一章的知识点&#xff0c;在此基础上&#xff0c;增加了练习题帮助大家理解一些重要的概念✅&#xff1b;同时&#xff0c;由于原文使用的C语言代码&#xff0c;不利于学习Java语言的同学实践&#xff0c;…

websocket基础使用学习

websocket基础使用学习 一、websocket是什么&#xff1f;二、使用步骤1.websocket服务的安装与启动安装服务连接与发消息 总结 一、websocket是什么&#xff1f; 以前&#xff0c;很多网站为了实现推送技术&#xff0c;所用的技术都是Ajax 轮询。轮询是在特定的的时间间隔&…

对于CDA一级考试该咋准备??!

一、了解考试内容和结构 CDA一级考试主要涉及的内容包括&#xff1a;数据分析概述与职业操守、数据结构、数据库基础与数据模型、数据可视化分析与报表制作、Power BI应用、业务数据分析与报告编写等。 CDA Level Ⅰ 认证考试大纲:https://edu.cda.cn/group/4/thread/174335 …

神经网络原理

神经网络原理是一种模拟人脑的机器学习技术&#xff0c;通过大量的神经元和层次化的连接进行信息处理和学习。 图1 神经元 神经网络由许多简单的计算单元或“神经元”组成&#xff0c;这些神经元通过连接传递信息。每个连接都有一个权重&#xff0c;用于调整传递的信号强度。这…

中国电信股份有限公司江西分公司招聘信息 7.5日截止

法律事务管理(南昌) 学历要求 本科及以上学历 岗位职责 1.依据国家法律、法规和相关规章规定,为公司其他部门提供日常法律服务与支持; 2.负责公司各类合同审核工作; 3.负责公司法律文件的起草和法律事务谈判; 4.围绕与公司业务有关的法律问题及法…

【简单讲解下OneFlow深度学习框架】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

算法金 | 协方差、方差、标准差、协方差矩阵

大侠幸会&#xff0c;在下全网同名「算法金」 0 基础转 AI 上岸&#xff0c;多个算法赛 Top 「日更万日&#xff0c;让更多人享受智能乐趣」 抱个拳&#xff0c;送个礼 1. 方差 方差是统计学中用来度量一组数据分散程度的重要指标。它反映了数据点与其均值之间的偏离程度。在…

AI in Law 法律领域AI应用-基于DeepNLP AI App Store 评论评测和排名

来源: quora 社区: https://deepnlpaistore.quora.com/ github: https://github.com/rockingdingo/deepnlp/blob/master/store/law.md 法律领域哪些AI服务应用更能满足用户的需求&#xff0c;排名最高? 参考deepnlp.org网站根据用户真实评论打分和show case分享&#xff0c;分…

鸿蒙开发设备管理:【@ohos.geolocation (位置服务)】

位置服务 说明&#xff1a; 本模块首批接口从API version 7开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 导入模块 import geolocation from ohos.geolocation;geolocation.on(‘locationChange’) on(type: ‘locationChange’, request: L…

【Red Hat】 Red Hat 系统提示未注册订阅管理,并进行阿里yum源更新的解决方案

目录 &#x1f30a;1. 问题说明 &#x1f30a;2. 解决方案 &#x1f30d;2.1 Redhat 官网注册与订阅 &#x1f30d;2.2 Redhat 登录已订阅账号 &#x1f30d;2.3 更换 Redhat 为阿里yum源 &#x1f30d;2.4 验证 &#x1f30a;1. 问题说明 使用 yum makecache 或 yum up…

生命在于学习——Python人工智能原理(2.3.4)

三、Python的数据类型 3.2 Python的组合数据类型 3.2.4 字典-映射类型 映射类型是键-值数据项的组合&#xff0c;每一个元素都是一个键-值对&#xff0c;即元素是&#xff08;key&#xff0c;value&#xff09;&#xff0c;元素之间是无序的&#xff0c;键-值对&#xff08;…

STM32CUBEMX配置USB虚拟串口

STM32CUBEMX配置USB虚拟串口 cubemx上默认配置即可。 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传 配置完后生成工程&#xff0c;主要就是要知道串口的收发接口就行了。 发送&#xff1a;CDC_Transmit_FS()&#xff0c;同时记得包含头文件#include “…

大数据可视化实验(六)——ECharts与pyecharts数据可视化

目录 一、实验目的... 1 二、实验环境... 1 三、实验内容... 1 1、ECharts可视化制作.. 1 1&#xff09;使用ECharts绘制折线图显示一周的天气变换。... 1 2&#xff09;使用ECharts绘制柱状图显示商品销量的变化。... 4 2、pyecharts可视化制作.. 7 1&#xff09;使用…

Webpack: 深入理解图像加载原理与最佳实践

概述 图形图像资源是当代 Web 应用的最常用、实惠的内容、装饰元素之一&#xff0c;但在 Webpack 出现之前对图像资源的处理复杂度特别高&#xff0c;需要借助一系列工具(甚至 Photoshop)完成压缩、雪碧图、hash、部署等操作。 而在 Webpack 中&#xff0c;图像以及其它多媒体…

前端Web开发HTML5+CSS3+移动web视频教程 Day3 CSS 第1天

P29 - P43 从此开始进入 CSS 的学习。前面都是 HTML 的学习。 CSS 的作用&#xff1a;美化。 HTML 只是规定了网页内容有哪些&#xff0c;在网页中显示的位置默认是从上到下显示&#xff0c;还带有默认效果&#xff0c;比如超链接有颜色有下划线&#xff0c;无序列表有小圆点…

【算法训练记录——Day37】

Day37——贪心Ⅴ 1.leetcode_56合并区间 1.leetcode_56合并区间 思路&#xff1a;排序&#xff0c;如果重叠&#xff0c;更新right 为max(right, curVal), 不重叠就加入res,需要单独考虑最后一次&#xff0c;因为每次都是在下一次遍历开始时判断是否加入res&#xff0c;因此 当…

平衡二叉搜索树/AVL树

VAL树的特性 左右子树高度差的绝对值不超过1。&#xff08;即左右子树高度差取值为-1&#xff0c;0&#xff0c;1&#xff09;且左右子树均为VAL树右子树的值大于左子树的值 在搜索二叉树中我们提及了搜索二叉树的退化问题。 当有序&#xff08;升序或降序&#xff09;地插入…

人工智能类SCI,1区TOP,3个月可录!

今天给大家推荐一本人工智能类SCIE领域的SCI&#xff0c;此期刊为我处目前合作的重点期刊&#xff01;影响因子7.0-8.0之间&#xff0c;JCR1区&#xff0c;中科院2/1区&#xff08;TOP&#xff09;&#xff0c;最重要的是审稿周期较短&#xff0c;对急投的学者较为友好&#xf…

MATLAB-振动问题:两自由度耦合系统自由振动

一、基本理论 二、MATLAB实现 以下是两自由度耦合系统自由振动质量块振动过程动画显示的MATLAB程序。 clear; clc; close allx0 1; D1 40; D12 8; D2 D1; m1 1; omega0 sqrt(D1/m1); k1 D12 / D1; k2 D12 / D2; k sqrt(k1 * k2); omegazh omega0 * sqrt(1 k); omeg…

SpringBoot使用Spark的DataFrame API

什么是Spark&#xff1f; Apache Spark是一个开源的分布式计算系统&#xff0c;它提供了一个快速和通用的集群计算平台。Spark 能够处理大规模数据&#xff0c;支持多种编程语言&#xff0c;如Scala、Java和Python&#xff0c;并且具有多种高级功能&#xff0c;包括SQL查询、机…