- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python元组拆包和具名元组解析实例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言 。
在Python中元组是一个相较于其他语言比较特别的一个内置序列类型。有些python入门教程把元组成为“不可变的列表”,这种说法是不完备的,其并没有完整的概括元组的特点。除了用作不可变的列表,它还可以用于没有字段名的数据记录。下面的内容就围绕元组作为数据记录属性展开,并介绍带字段名的具名元组函数namedtuple,列表属性不再本文中叙述.
元组对于数据的记录 。
元组中的每个元素都存放了记录中一个字段的数据,外加这个字段的位置,正是这个位置信息给数据赋予了意义.
下面的一段代码就演示了元组被当作记录来使用。如果在任何的表达式里我们在元组内对元素排序,这些元素多携带的信息就会丢失,因为这些信息是跟它们的位置强关联的.
1
2
3
4
5
6
7
8
9
10
11
|
#把元组作记录
>>> xiaoming, xiaohua
=
(
16
,
18
)
>>> xiaoming
16
>>> students_info
=
[(
'xiaoming'
,
16
), (
'xiaohua'
,
18
), (
'hanmeimei'
,
20
)]
>>>
for
student
in
students_info:
print
(
'%s is %d years old.'
%
student)
xiaoming
is
16
years old.
xiaohua
is
18
years old.
hanmeimei
is
20
years old.
>>>
|
在这个示例中,我们把元组(16,18)里的元素分别赋值给变量xiaoming,xiaohua。同样在for循环中,一个%运算符就把student元组里的元素对应到了Print函数的格式字符串空档中。这两个都是元组拆包的应用。 元组拆包可以应用到任何可迭代对象上,唯一的硬性要求是,被可迭代对象中的元素数量必须要跟接受这些元素的元组的空档数一致。除非用*来表示忽略多余的元素.
元组拆包 。
最好辨认的元组拆包形式就是平行赋值 ,也就是把一个可迭代对象里的元素,一并赋值到由对应的变量组成的元组中。例如:
1
2
|
>>> age_list
=
(
16
,
18
)
>>> xiaoming, xiaohua
=
age_list
#这里就是元组拆包
|
另一个我们熟悉的平行赋值的例子就是交换两个变量的值:
1
|
>>> a, b
=
b, a
#Python就是如此的优雅
|
还可以用*运算符把一个可迭代对象拆开作为函数的参数:
1
2
3
4
5
6
7
8
|
>>>
divmod
(
20
,
8
)
(
2
,
4
)
>>> t
=
(
20
,
8
)
>>>
divmod
(
*
t)
(
2
,
4
)
>>> quotient, remainder
=
divmod
(
*
t)
>>> quotient, remainder
(
2
,
4
)
|
用*来处理剩下的元素 。
在Python中,函数用*args来获取不确定数量的参数算是一种经典写法了。在Python3中,这个概念被扩展到了平行赋值中:
1
2
3
4
5
6
7
8
9
|
>>> a, b,
*
rest
=
range
(
5
)
>>> a, b, rest
(
0
,
1
, [
2
,
3
,
4
])
>>> a, b,
*
rest
=
range
(
3
)
>>> a, b, rest
(
0
,
1
, [
2
])
>>> a, b,
*
rest
=
range
(
2
)
>>> a, b, rest
(
0
,
1
, [])
|
在平行赋值中,*运算符前缀智能用在一个变量名前面,但是这个变量可以出现在赋值表达式的任意位置:
1
2
3
4
5
6
|
>>> a,
*
others, b, c
=
range
(
5
)
>>> a, others, b, c
(
0
, [
1
,
2
],
3
,
4
)
>>>
*
others, a, b, c
=
range
(
5
)
>>> others, a, b, c
([
0
,
1
],
2
,
3
,
4
)
|
具名元组 。
在Python中,collections.namedtuple是一个工厂函数,它可以用来构建一个带字段名的元组和一个有名字的类。 用namedtuple构建的类的实例所消耗的内存跟元组是一样的,因为字段名都被存在对应的类里面。这个实例跟普通的对象实例比起来也要小一些,因为python不会用 dict 来存放这些实例的属性.
还是使用上面的小明和小华的例子来展示一下具名元组:
1
2
3
4
5
6
7
8
9
|
>>>
from
collections
import
namedtuple
>>> Student
=
namedtuple(
'Student'
,
'name age gender'
)
>>> xiaoming
=
Student(
'xiaoming'
,
16
,
'boy'
)
>>> xiaoming
Student(name
=
'xiaoming'
, age
=
16
, gender
=
'boy'
)
>>> xiaoming.age
16
>>> xiaoming[
2
]
'boy'
|
Student = namedtuple(‘Student', ‘name age gender'),创建一个具名元组,需要两个参数,一个是类名,另一个是类的各个字段名。后者可以是有多个字符串组成的可迭代对象,或者是有空格分隔开的字段名组成的字符串(比如本示例)。具名元组可以通过字段名或者位置来获取一个字段的信息.
具名元组的特有属性 。
类属性_fields:包含这个类所有字段名的元组 。
1
2
|
>>> xiaoming._fields
(
'name'
,
'age'
,
'gender'
)
|
类方法_make(iterable):接受一个可迭代对象来生产这个类的实例,作用等价于Student 。
1
2
3
4
5
|
(
*
xiaohua_info)
>>> xiaohua_info
=
(
'xiaohua'
,
18
,
'girl'
)
>>> xiaohua
=
Student._make(xiaohua_info)
>>> xiaohua
Student(name
=
'xiaohua'
, age
=
18
, gender
=
'girl'
)
|
实例方法_asdict():把具名元组以collections.OrdereDict的形式返回,可以利用它来把元组里的信息友好的展示出来 。
1
2
3
4
5
6
7
|
>>> xiaohua._asdict()
OrderedDict([(
'name'
,
'xiaohua'
), (
'age'
,
18
), (
'gender'
,
'girl'
)])
>>>
for
key, value
in
xiaohua._asdict().items():
print
(key,
':'
,value)
name : xiaohua
age :
18
gender : girl
|
总结 。
以上所述是小编给大家介绍的Python元组拆包和具名元组解析实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。
原文链接:http://www.jqhtml.com/10804.html 。
最后此篇关于Python元组拆包和具名元组解析实例详解的文章就讲到这里了,如果你想了解更多关于Python元组拆包和具名元组解析实例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
有没有一种方法可以使用标准类型构造函数(例如 int、set、dict、list、tuple 等)以用户定义的方式将用户定义类的实例强制转换为其中一种类型?例如 class Example:
我知道这个问题在Stackoverflow中有很多问题,但是即使有很多答案,这些答案也帮不了我什么,也没有找到答案。 在我的WebAPP中,它可以正常工作,但是当我将其转换为API时,它失败了(主题标
这个问题已经有答案了: Why does the ternary operator unexpectedly cast integers? (3 个回答) 已关闭 9 年前。 最近遇到一个Java的陷
我尝试使用 FirebaseApp.configure() 配置 Firebase,但遇到以下崩溃: *** Terminating app due to uncaught exception 'c
我有一个自连接员工实体类,其中包含与其自身相关的 id、name 和 ref 列。我想创建它的新实例并将其保存到数据库。 首先我创建了一个 Employee 类的实例并将其命名为 manager。然后
我有一个用于添加新公寓的表单,在该表单中我有一个下拉列表,用户可以在其中选择负责的人员。 显然,当您从下拉列表中选择并尝试保存公寓时,我的应用程序认为该人已被修改。它给了我下面的错误,指示我应该首先保
从 Visualforce 页面,我需要检索我们组织的 salesforce 实例的 URL,而不是 Visual Force URL。 例如我需要https://cs1.salesforce.com
我遇到了一些可能的问题答案,但这是关于从 Hibernate 3.4.0GA 升级到 Hibernate 4.1.8 的问题。所以这曾经在以前的版本下工作,我已经四处搜索了为什么它在这个新版本中出现了
似乎一遍又一遍地问这个问题,我仍然找不到解决我问题的答案。我在下面有一个域模型。每个新创建或更新的“安全用户”都需要我确保其具有配置文件,如果没有,则创建一个新的配置文件并分配给它。 配置文件的要求相
我很难调试为什么 JPA 不级联我的 @ManyToMany 关系。我发现的所有答案都与缺少级联语句有关。但我确实拥有它们并且仍然得到: Caused by: org.hibernate.Transi
Play 服务 API 表明有一个叫做 Instance ID 的东西 但是,在 Android Studio 中包含以下内容后,我无法导入 InstanceID 类 compile "com.goo
我正在使用 Seam 框架。我有 2 个实体: 请求.java @Entity @Table(name = "SRV_REQUEST") public class Request { private
This question处理构建一个适当的Monad来自单子(monad)的实例,但仅在某些约束下 - 例如Set .诀窍是将其包装成 ContT ,它将约束推迟到包装/展开其值。 现在我想对 Ap
我正在尝试执行此查询: StringBuffer sb = new StringBuffer(); sb.append("select p from PointsEntity p " + "where
我试图了解是否可以更改我的 hibernate 配置并使用单个 MySQL 实例(而不是我当前拥有的多个 MySQL 实例): 我有一个使用 hibernate 的 Java 应用程序,与 2 个模式
我有一个选项卡滑动布局,其中包括四个选项卡,每个选项卡都有自己的布局和 fragment ,在我的主要 Activity 布局中,viewpager 参与更改选项卡。特定 View (选项卡)在应用程
我看到很多帖子声称他们正在运行 MySql 的 RDS 实例,但无法连接到该实例,但我没有运行 RDS。 我使用 EC2 实例来托管我的 WordPress 博客,该博客是使用 Web 平台安装程序安
因为我在我的 ec-2 实例上的 python 虚拟环境中运行应用程序( Airflow ),并且我想在同一个 ec2 实例上的默认 python 环境中运行命令,所以我认为 ssh 到我自己的实例更
这个问题已经有答案了: How to fix the Hibernate "object references an unsaved transient instance - save the tra
例子: run APP1 .. ... run APP1 ... run APP2 如何在 APP2 中对 Vue 说我需要调用 APP1?
我是一名优秀的程序员,十分优秀!