Python :数据模型
一. 什么是数据模型?
Python数据模型是Python对象系统的抽象,通过一组特殊方法(如__init__、__len__等)和协议(如迭代协议、上下文管理协议),定义了对象如何与语言的内置功能(如len()、for循环等)交互。
核心思想
- 统一性:所有对象(如列表、字典、自定义类)的行为都通过相同的特殊方法实现。
- 灵活性:通过实现特殊方法,可以让自定义对象支持内置操作(如
+、in、切片等)。
例子
import collections
Card = collections.namedtuple('Card', ['rank', 'suit'])
class FrenchDeck:ranks = [str(n) for n in range(2, 11)] + list('JQKA')suits = 'spades diamonds clubs hearts'.split()def __init__(self):self._cards = [Card(rank, suit) for suit in self.suitsfor rank in self.ranks]def __len__(self):return len(self._cards)def __getitem__(self, position):return self._cards[position]
解释
模块导入:
import collections导入了 Python 标准库中的
collections模块。命名元组定义:
Card:
Card = collections.namedtuple('Card', ['rank', 'suit'])使用
namedtuple创建了一个名为Card的简单类,表示扑克牌的一张牌。每个Card对象有两个属性:
rank:表示牌的点数(如'2','J','A'等)。suit:表示牌的花色(如'spades','diamonds'等)。类定义:
FrenchDeck:
- 定义了一个名为
FrenchDeck的类,表示一副标准的 52 张扑克牌。- 类属性:
ranks = [str(n) for n in range(2, 11)] + list('JQKA') suits = 'spades diamonds clubs hearts'.split()
ranks:表示牌的所有点数,包括数字牌('2'到'10')和字母牌('J','Q','K','A')。suits:表示牌的所有花色('spades'黑桃、'diamonds'方片、'clubs'梅花、'hearts'红心)。- 构造函数
__init__:初始化时创建了一副完整的扑克牌,存储在
def __init__(self): self._cards = [Card(rank, suit) for suit in self.suits for rank in self.ranks]_cards列表中。通过列表推导式生成所有可能的牌组合。- 方法
__len__:实现了特殊方法
def __len__(self): return len(self._cards)__len__,使得可以通过len(deck)获取扑克牌的数量。- 方法
__getitem__:实现了特殊方法
def __getitem__(self, position): return self._cards[position]__getitem__,使得可以通过索引访问扑克牌,例如deck[0]。
常用特殊方法:
| 方法 | 对应操作 |
|---|---|
__init__ | 对象初始化 |
__repr__ / __str__ | 字符串表示 |
__len__ | len(obj) |
__getitem__ | obj[key](支持索引和切片) |
__iter__ | for x in obj(迭代) |
__enter__ / __exit__ | with语句(上下文管理) |
迭代协议
实现__iter__和__next__方法,让对象支持for循环:
class CountDown:def __init__(self, start):self.current = startdef __iter__(self):return selfdef __next__(self):if self.current <= 0:raise StopIterationelse:self.current -= 1return self.current + 1for num in CountDown(3):print(num) # 输出: 3 2 1
解释
类定义:
CountDown:
定义了一个名为
CountDown的类,用于实现倒计时功能。构造函数
__init__:
def __init__(self, start): self.current = start初始化时接收一个参数
start,表示倒计时的起始值,并将其赋值给实例属性self.current。方法
__iter__:
def __iter__(self): return self实现了可迭代协议,使得该类的实例可以作为迭代器使用。返回自身(
self)。方法
__next__:
def __next__(self): if self.current <= 0: raise StopIteration else: self.current -= 1 return self.current + 1实现了迭代器协议中的
__next__方法:
- 如果当前值
self.current小于或等于 0,则抛出StopIteration异常,表示迭代结束。- 否则,将
self.current减 1,并返回减 1 前的值(即当前值)。使用场景:
- 该类可以通过
for循环或手动调用next()方法进行倒计时。- 示例:
输出结果:countdown = CountDown(5) for value in countdown:print(value)
5 4 3 2 1
上下文管理协议
实现__enter__和__exit__方法,支持with语句:
class Timer:def __enter__(self):self.start = time.time()return selfdef __exit__(self, exc_type, exc_val, exc_tb):self.end = time.time()print(f"耗时: {self.end - self.start:.2f}秒")with Timer():time.sleep(1) # 输出: 耗时: 1.00秒
解释
类定义:
Timer:
定义了一个名为
Timer的类,用于测量代码块的执行时间。方法
__enter__:
def __enter__(self): self.start = time.time() return self
- 实现了上下文管理协议中的
__enter__方法。- 在进入
with语句块时,记录当前时间(以秒为单位)并存储在实例属性self.start中。- 返回自身(
self),以便在with语句块中可以访问该对象。方法
__exit__:
def __exit__(self, exc_type, exc_val, exc_tb): self.end = time.time() print(f"耗时: {self.end - self.start:.2f}秒")
- 实现了上下文管理协议中的
__exit__方法。- 在退出
with语句块时,记录当前时间(以秒为单位)并存储在实例属性self.end中。- 计算执行时间(
self.end - self.start),并以两位小数的格式打印到控制台。使用场景:
- 通过
with语句使用Timer类来测量代码块的执行时间。- 示例:
with Timer(): time.sleep(1) # 输出: 耗时: 1.00秒
- 在
with语句块中调用了time.sleep(1),模拟了一个耗时 1 秒的操作。Timer类会自动计算并打印出这段代码的执行时间。
让自定义类支持切片
class MySequence:def __init__(self, data):self.data = datadef __len__(self):return len(self.data)def __getitem__(self, index):if isinstance(index, slice):return self.data[index.start : index.stop : index.step]else:return self.data[index]seq = MySequence([0, 1, 2, 3, 4])
print(seq[1:3]) # [1, 2](支持切片!)
鸭子类型(Duck Typing)
Python不检查对象的类型,而是检查对象是否实现了特定的方法(即是否“像鸭子一样叫”)。
示例:
class FakeList:def __len__(self):return 10def __getitem__(self, index):return index * 2fake = FakeList()
print(len(fake)) # 10(调用__len__)
print(fake[5]) # 10(调用__getitem__)
print(isinstance(fake, list)) # False,但行为类似列表!
相关文章:
Python :数据模型
一. 什么是数据模型? Python数据模型是Python对象系统的抽象,通过一组特殊方法(如__init__、__len__等)和协议(如迭代协议、上下文管理协议),定义了对象如何与语言的内置功能(如…...
idea超级AI插件,让 AI 为 Java 工程师
引言 用户可在界面中直接通过输入自然语言的形式描述接口的需求,系统通过输入的需求自动分析关键的功能点有哪些,并对不确定方案的需求提供多种选择,以及对需求上下文进行补充,用户修改确定需求后,系统会根据需求设…...
施磊老师c++笔记(五)
继承与多态-深入掌握oop语言最强大的机制 文章目录 继承与多态-深入掌握oop语言最强大的机制1.继承的基本意义2.派生类的构造过程3.重载,隐藏,覆盖4.虚函数, 静态绑定和动态绑定--面试重点5.虚析构函数--重点在于什么呢时候用6.再讨论虚函数和动态绑定7.理解多态到底是什么8.理…...
µCOS-III从入门到精通 第十四章(软件定时器)
参考教程:【正点原子】手把手教你学UCOS-III实时操作系统_哔哩哔哩_bilibili 一、软件定时器简介 1、定时器的概念与种类 (1)定时器的概念:从指定的时刻开始,经过一个指定时间,然后触发一个超时事件&…...
MySQL数据库复杂的增删改查操作
在前面的文章中,我们主要学习了数据库的基础知识以及基本的增删改查的操作。接下去将以一个比较实际的公司数据库为例子,进行讲解一些较为复杂且现时需求的例子。 基础知识: 一文清晰梳理Mysql 数据库基础知识_字段变动如何梳理清楚-CSDN博…...
KCD 北京站丨Volcano 邀您畅聊云原生智能调度技术与应用
AI与云原生技术正以前所未有的速度改变着我们的世界,而云原生技术则如同一座坚实的桥梁,连接着传统IT与现代化的数字世界。当AI与云原生相遇,它们相互赋能,相互促进,为开发者们打开了一个全新的技术宇宙。 3 月 15 日&…...
BLEU评估指标
一、介绍 用于评估模型生成的句子和实际句子差异的指标,取值在[0,1],匹配度高就距离1近,反之距离0近。这个指标计算代价小,容易理解,与语言无关,与人类评价结果高度相关。 BLEU主要基于n-gram匹配&#x…...
高效自动化测试:打造Python+Requests+Pytest+Allure+YAML的接口测试框架
一、背景 在快节奏的开发周期中,如何确保接口质量?自动化测试是关键。通过构建标准化、可复用的测试框架,能显著提升测试效率与准确性,为项目质量保驾护航[1][7]。 二、目标 ✅ 核心目标: ● 实现快速、高效的接口测试…...
如何修复 Tauri 发布后程序运行时显示 `asset not found: index.html` 的问题
如何修复 Tauri 发布后程序运行时显示 asset not found: index.html 的问题 在使用 Tauri 发布应用程序时,如果运行时出现 asset not found: index.html 的错误,通常是因为 Tauri 无法找到或正确加载前端资源文件(如 index.html)…...
BSides Vancouver: 2018 (Workshop)
BSides Vancouver: 2018 (Workshop) 来自 <https://www.vulnhub.com/entry/bsides-vancouver-2018-workshop,231/> 1,将两台虚拟机网络连接都改为NAT模式 2,攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23…...
rStar论文精读
论文简介 论文标题:《Mutual reasoning makes smaller LLMs stronger problem-solvers》 论文地址:https://arxiv.org/abs/2408.06195 录用会议:ICLR2025 背景与挑战 挑战1:在SLM中平衡exploration与exploitation。一些方法有很…...
【动态规划】对局匹配 (分组线性DP)
题目详情 问题描述: 小明喜欢在一个围棋网站上找别人在线对弈。这个网站上所有注册用户都有一个积分,代表他的围棋水平。 小明发现网站的自动对局系统在匹配对手时,只会将积分差恰好是K的两名用户匹配在一起。如果两人分差小于或大于K…...
python 提取视频中的音频
在Python中提取视频中的音频,你可以使用moviepy库,这是一个非常强大且易于使用的库,专门用于视频编辑。以下是如何使用moviepy来提取视频中的音频的步骤: 安装moviepy 首先,你需要安装moviepy。你可以通过pip安装它&a…...
self.cls_token在 Vision Transformer (ViT) 模型中的训练阶段和推理阶段的行为和作用的异同
self.cls_token 在 Vision Transformer (ViT) 模型中,在训练阶段和推理阶段的行为和作用是不同的,而且它的值在训练过程中会发生变化。 1. self.cls_token 的作用 在 ViT 中,self.cls_token 是一个特殊的、可学习的嵌入向量(emb…...
【量化科普】Leverage,杠杆
【量化科普】Leverage,杠杆 🚀量化软件开通 🚀量化实战教程 在量化投资领域,杠杆(Leverage)是一个核心概念,它允许投资者通过借入资金来增加投资规模,从而放大投资收益或亏损。简…...
247g 的工业级电调,如何让无人机飞得更 “聪明“?——STONE 200A-M 深度测评
一、轻量化设计背后的技术取舍 当拿到 STONE 200A-M 时,247g 的重量让人意外 —— 这个接近传统 200A 电调 70% 的重量,源自 1205624.5mm 的紧凑结构(0.1mm 公差控制)。实测装机显示,相比同规格产品,其体积…...
Maven Deploy Plugin如何使用?
在Java开发中,Maven是一个非常重要的构建工具。它不仅可以管理项目的依赖关系,还能帮助我们打包和发布项目。在Maven中,deploy插件是一个很实用的功能,它可以将构建好的项目发布到远程仓库。今天,就来聊聊如何使用Mave…...
Node.js:快速启动你的第一个Web服务器
Node.js 全面入门指南 文章目录 Node.js 全面入门指南一 安装Node.js1. Windows2. MacOS/Linux 二 配置开发环境1. VSCode集成 三 第一个Node.js程序1. 创建你的第一个Node.js程序 四 使用Express框架1. 快速搭建服务器 一 安装Node.js 1. Windows 以下是Windows环境下Node.j…...
自定义日志回调函数实现第三方库日志集成:从理论到实战
一、应用场景与痛点分析 在开发过程中,我们经常会遇到以下场景: 日志格式统一:第三方库使用自己的日志格式,导致系统日志混杂,难以统一管理和分析。日志分级过滤:需要动态调整第三方库的日志输出级别&…...
Linux练级宝典->任务管理和守护进程
任务管理 进程组概念 每个进程除了进程ID以外,还有一个进程组,进程组就是一个或多个进程的集合 同一个进程组,代表着他们是共同作业的,可以接收同一个终端的各种信号,进程组也有其唯一的进程组号。还有一个组长进程&a…...
C语言:计算并输出三个整数的最大值 并对三个数排序
这是《C语言程序设计》73页的思考题。下面分享自己的思路和代码 思路: 代码: #include <stdio.h> int main() {int a,b,c,max,min,mid ; //设置大中小的数分别为max,mid,min,abc为输入的三个数printf("ple…...
工具(十二):Java导出MySQL数据库表结构信息到excel
一、背景 遇到需求:将指定数据库表设计,统一导出到一个Excel中,存档查看。 如果一个一个弄,很复杂,耗时长。 二、写一个工具导出下 废话少絮,上码: 2.1 pom导入 <dependency><grou…...
如何设计微服务及其设计原则?
微服务架构是一种将大型单体应用拆分成多个小型、自治服务的设计方式,每个服务专注于单一的业务功能。设计微服务时,需要遵循以下原则和最佳实践: 1. 单一职责原则 核心思想: 每个微服务都应该只负责一块独立的业务功能。这使得…...
ACL初级总结
ACL–访问控制列表 1.访问控制 在路由器流量流入或者流出的接口上,匹配流量,然后执行相应动作 permit允许 deny拒绝 2.抓取感兴趣流 3.ACL匹配规则 自上而下逐一匹配,若匹配到了则按照对应规则执行动作,而不再向下继续匹配 思科:ACL列表末尾隐含一条拒绝所有的规则 华为:AC…...
调优案例一:堆空间扩容提升吞吐量实战记录
📝 调优案例一:堆空间扩容提升吞吐量实战记录 🔧 调优策略:堆空间扩容三部曲 # 原配置(30MB堆空间) export CATALINA_OPTS"$CATALINA_OPTS -Xms30m -Xmx30m"# 新配置(扩容至120MB&am…...
C语言 —— 此去经年梦浪荡魂音 - 深入理解指针(卷一)
目录 1. 内存和地址 2. 指针变量和地址 2.1 取地址操作符(&) 2.2 指针变量 2.3 解引用操作符 (*) 3. 指针的解引用 3.1 指针 - 整数 3.2 void* 指针 4. const修饰指针 4.1 const修饰变量 4.2 const修饰指针变量 5…...
计算机毕业设计:留守儿童的可视化界面
留守儿童的可视化界面mysql数据库创建语句留守儿童的可视化界面oracle数据库创建语句留守儿童的可视化界面sqlserver数据库创建语句留守儿童的可视化界面springspringMVChibernate框架对象(javaBean,pojo)设计留守儿童的可视化界面springspringMVCmybatis框架对象(javaBean,poj…...
golang算法二叉树对称平衡右视图
100. 相同的树 给你两棵二叉树的根节点 p 和 q ,编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同,并且节点具有相同的值,则认为它们是相同的。 示例 1: 输入:p [1,2,3], q [1,2,3] 输出:…...
c++20 Concepts的简写形式与requires 从句形式
c20 Concepts的简写形式与requires 从句形式 原始写法(简写形式)等效写法(requires 从句形式)关键区别说明:组合多个约束的示例:两种形式的编译结果:更复杂的约束示例:标准库风格的约…...
Chatbox通过百炼调用DeepSeek
解决方案链接:评测|零门槛,即刻拥有DeepSeek-R1满血版 方案概览 本方案以 DeepSeek-R1 满血版为例进行演示,通过百炼模型服务进行 DeepSeek 开源模型调用,可以根据实际需求选择其他参数规模的 DeepSeek 模型。百炼平台…...
