numpy、pandas内存优化操作整理
前言
python作为一款不怎么关注数据类型的语言,不同类型的数据可以往同一个变量中放置
这也就直接导致,作为熟悉C++这种一个变量只有一个类型的程序员来说,在解读python程序时,想搞清楚变量中到底存的是什么数据类型的时候时常很头疼
所以说,良好的编程习惯真的很重要
虽然上面的话跟这篇文章关系不大,但是我就是想吐槽一下 ;p
下面是我优化某个python项目的其中某个模块的内存时,对python中的numpy/pandas库调研得出的一些优化操作,在此分享给大家
注:有的地方我理解的也不是很透彻,在此仅作为心得记录,有任何不对的地方欢迎在评论区进行指正
一、通用优化操作
1. 指定合适的数据类型
如果数据的值域可以限制在较小的范围内,可手动指定其dtype
类型进行限制
2. 避免copy
1)切片/索引层面
切片或其他索引方式中是否涉及拷贝,这部分就主要决定于各个库中具体实现细节了,可看下面对应章节部分
- 原生python拷贝数组时注意的一个小细节:
list1 = [...]1.类似浅拷贝/引用,操作对象为同一个,无copy,操作list2就是操作list1: list2 = list1 2.类似深拷贝,涉及copy,list2与list1不是同一个对象: list2 = list1[:]
2)计算过程层面
如果输入数据可以“原地”处理,且可以把计算过程拆分成“原地”处理的步骤,或是库里提供了可以“原地”计算的函数,则尽量进行拆分和替换“原地”处理的函数
下面是数组归一化
时,将步骤进行拆分节省内存的一个例子:
- 简单的实现,但是会产生临时数组的内存开销
def Normalize(lst : list):lst_range = lst.max - lst.minreturn (lst - lst.min) / lst_range
- 拆分步骤,每一步都是“原地”操作
def Normalize(lst : list):lst_range = lst.max - lst.minlst -= lst.minlst /= lst_range
3. 文件读取
- chunk读取:这个也算是流程优化的一部分
读取文件时是否是一次性读取完毕?分块读取是否会影响到流程?如果可以分块读取,那么读取接口是否有提供类似chunksize
的参数?
一次读取的内容过多,一方面是会直接影响到IO内存,另一方面也是考虑到,大部分情况下实际要处理的数据并没有那么多,所以不如限制每次读取的数据大小,够用即可,用完再取 - index索引:如果输入数据是有组织有结构地进行存储,那么通常可以通过建索引的方式记录数据的关键信息,在需要取用的时候就能通过索引快速取用自己所需的部分,一方面加速处理速度,另一方面内存也能更低
4. 数据结构的选取
主要是选用跟实际需求更匹配的数据结构,比如dict会浪费至少30%以上的内存,如果条件允许,可以通过一系列的方式对其进行优化
- 换用自定义class
- class +
__slots__
:加上限定,能省略class内的一些隐性内存开销 - namedtuple:同样是限定,但与tuple类似不可更改
- recordclass:基于namedtuple的可变变体(使用方式可看这里)
二、numpy相关
1. 使用sparse array
虽然ndarray适用于存储大量数据,但如果其中大部分数据都是空时,用稀疏矩阵能更省空间
2. 检查库方法的内部实现
库提供的方法为了泛用性,内部一般会对输入数据的类型进行限定,如果输入数据的类型与其预期不符,可能会造成更大的内存消耗
比如:一个库方法内部会将输入数据转为int64
进行操作,如果输入的是int16
,那么消耗内存会是int16 + int64
,可能还不如把输入数据直接设置为int64
并设置“原地”操作
3. indexing / slicing
numpy中有两种indexing方式,不同的方式返回值不同:可能返回view(类似浅拷贝/引用),也可能返回copy
- 判断view/copy方式:可以简单地通过
.base
属性是否为None来判断 - basic indexing:
[]
中为slice/integer
或一个元组(仅包含slice/integer
)时触发
与python原生list切片不同,返回view - Advanced indexing:
[]
中为非元组sequence / ndarray( of integer/bool)
或一个元组(包含至少一个sequence/ndarray
)时触发
返回copy
示例:>>> import numpy as np >>> data1 = np.arange(9).reshape(3, 3) # reshape returns a view at most time >>> data1 array([[0, 1, 2],[3, 4, 5],[6, 7, 8]]) >>> data1.base array([0, 1, 2, 3, 4, 5, 6, 7, 8]) >>> >>> data2 = data1[[1, 2]] # data2 is a copy >>> data2 array([[3, 4, 5],[6, 7, 8]]) >>> data2.base >>> >>> data1[[1, 2]]=[[10, 11, 12], [13, 14, 15]] # change data1 >>> data1 # 可能在 = 左边时不是copy?所以data1被改变了? array([[ 0, 1, 2],[10, 11, 12],[13, 14, 15]]) >>> data2 # data2 not changed array([[3, 4, 5],[6, 7, 8]])
.reshape()
:在大部分情况下,如果可以通过修改步长的方式来重建数组则会返回view;如果数组变得不再连续了(即修改步长重建不了了,比如ndarray.transpose
)则会返回copy
特殊情况:structured array
当ndarray的dtype使用named field
时,该数组变成一个有结构的数组(类似DataFrame一样有名字,而且给每一列指定不同的dtype)
>>> x = np.array([('Rex', 9, 81.0), ('Fido', 3, 27.0)],dtype=[('name', 'U10'), ('age', 'i4'), ('weight', 'f4')])
>>> x
array([('Rex', 9, 81.), ('Fido', 3, 27.)], dtype=[('name', '<U10'), ('age', '<i4'), ('weight', '<f4')])
- Individual field:返回view
>>> x['age'] array([9, 3], dtype=int32) >>> x['age'] = 5 >>> x array([('Rex', 5, 81.), ('Fido', 5, 27.)], dtype=[('name', '<U10'), ('age', '<i4'), ('weight', '<f4')])
- Multiple fields:返回copy(版本<=1.15)或view(版本> 1.15)
4. 文件处理
numpy读取文件时可使用memmap
对磁盘上的文件数据不读取到内存的同时当作ndarray一样去处理,但这个操作也存在一些限制:
- 如果读取内容很大,那么这可能会成为程序的瓶颈,因为磁盘操作始终比内存操作要慢
- 如果需要不同维度的索引/切片,那么只有符合默认结构的索引/切片会快,其余的会非常慢
解决方案:可选用其他文件读取库(如Zarr/HDF5)
三、pandas相关
1. 使用sparse array
与numpy类似,DataFrame同样可以设置成稀疏矩阵方式存储数据
2. [pyarrow]
pandas内部实际是使用numpy.ndarray来表示数据,但其对于 字符串 或 缺失值 的处理并不友好
而在pandas版本2.1以后(至少2.0以后),引入的pyarrow
可以极大地优化这两方面的处理
- 原本numpy中是用一组
PyObject*
存储数据,额外空间开销大;而pyarrow
中使用连续的char*
数组存储,对于大量短字符串的优化效果尤其明显 - 原本pandas中对于不同类型的缺失值有不同表示方式,而且对于整形的缺失值会自动转成浮点型,比较麻烦;而
pyarrow
中对不同类型都一套实现,数据的表示进行了统一
使用方式:实际使用时只需要在原本数据类型后面加上[pyarrow]
即可。如:
string
->string[pyarrow]
int64
->int64[pyarrow]
- 读取接口处可以指定
dtype_backend="pyarrow"
,有的还需指定engine="pyarrow"
3. indexing / slicing
非常重要的一点:pandas无法保证索引操作返回的是copy还是view
官方文档Copy on Write (CoW)的 previous behavior 小节第一句用了tricky to understand,可见它是有多难懂了
该页面主要介绍了让操作结果更加 predictable 的策略CoW,主要思路就是禁止在一行代码中更新多个对象
这样如果有多个对象实际指向同一份数据时,如果尝试更新其中一个对象的数据会触发copy,这样能保证另一份数据不会被影响;而且因为是更新时触发,尽量延缓了内存增加的时间
那么之前的代码中如果存在下面的操作时需格外注意,后续更新pandas版本后,结果可能与预期不符:
- chained indexing
一般表现为df[first_cond][second_cond] = ...
,即对两个连续索引的结果进行更新
因为df[first_cond]
得到的不确定为copy还是view,所以这里实际不确定操作的是一个还是两个对象(具体可看Why does assignment fail when using chained indexing)
注:可能还有其他形式的 chained indexing 需要格外注意,比如CoW中还提到下面的形式:df[col].replace(..., inplace=True)
- 解决办法:使用
.loc
取代多个索引(因为.loc
操作能保证操作数据本身),或是将多个操作整合到一步操作中
注:如果DataFrame是df.replace(col:{conditions}, inplace=True) or df[col] = df[col].replace(conditions)
Multi-Index
的,那么两个连续索引相当于是使用.loc
了,但是仍旧推荐使用.loc
4. 代码优化
- 按行迭代:用
itertuples
替换iterrows
(速度更快) - 循环操作:用
.apply/.applymap
替换循环 - 大数据计算:使用
pd.eval
,在大数据上的较复杂计算才有速度优化效果
相关文章:
numpy、pandas内存优化操作整理
前言 python作为一款不怎么关注数据类型的语言,不同类型的数据可以往同一个变量中放置 这也就直接导致,作为熟悉C这种一个变量只有一个类型的程序员来说,在解读python程序时,想搞清楚变量中到底存的是什么数据类型的时候时常很头…...
【OSG学习笔记】Day 5: 坐标系与变换节点(Transform)
在前面的学习中,我们对 OpenSceneGraph(OSG)有了基础的认识。 今天,我们将深入探讨 OSG 中的坐标系和变换节点(Transform),并通过平移、旋转、缩放模型以及父子节点层级变换的实战操作,加深对这些概念的理解。 坐标系 1. 基础坐标系 在 OSG 里,使用的是右手坐标系…...
使用 Logstash 迁移 MongoDB 数据到 Easysearch
大家好!在前面的文章中,我们已经详细介绍了如何通过 Logstash 和 Canal 工具实现 MySQL 数据向 Easysearch 的迁移。如果您正在使用 MongoDB 作为数据存储,并希望将其数据迁移到 Easysearch 中,这篇指南或许能为您提供一些帮助。 …...
在线查看【免费】vsd, vsdx/wmf, emf /psd, eps/pdf ,ofd, rtf/xmind/bpmn/eml/epub文件格式网
可以免费在线查看 .docx/wps/Office/wmf/ psd/ psd/eml/epub/dwg, dxf/ txt/zip, rar/ jpg/mp3 m.gszh.xyz m.gszh.xyz 免费支持以下格式文件在线查看类型 支持 doc, docx, xls, xlsx, xlsm, ppt, pptx, csv, tsv, dotm, xlt, xltm, dot, dotx, xlam, xla, pages 等 Office 办…...
富诺健康旗下运动营养品牌力爆(LIPOW):以冠军精神定义运动营养新时代
在全民健身热潮持续升温的今天,运动已不仅是竞技场上的较量,更是普通人突破自我的健康生活方式。《全民健身计划(2021-2025年)》中指出,“十三五”时期,全民健身国家战略深入实施,全民健身公共服…...
自定义多头注意力模型:从代码实现到训练优化
引言 在自然语言处理和序列生成任务中,自注意力机制(Self-Attention)是提升模型性能的关键技术。本文将通过一个自定义的PyTorch模型实现,展示如何构建一个结合多头注意力与前馈网络的序列生成模型(如文本或字符生成)。该模型通过创新的 MaxStateSuper 模块实现动态特征…...
vue部署到nginx服务器 启用gzip
要在使用Vue.js构建的应用程序上启用Nginx的Gzip压缩,你可以通过配置Nginx来实现这一功能,这样可以显著减少传输到客户端的数据量,从而加快页面加载速度。以下是如何配置Nginx以启用Gzip压缩的步骤: 1. 确认你的Vue.js应用已经构…...
Node.js和js到底什么关系
Node.js 和 JavaScript(JS)是紧密关联但本质不同的技术,它们的关系可以从以下几个关键维度进行解析: 1. 定义与角色 JavaScript: 一种高级、解释型的编程语言,最初设计用于浏览器端,负责网页的…...
如何开发一套TRS交易系统:架构设计、核心功能与风险控制
TRS(总收益互换)作为场外衍生品的重要工具,近年来在跨境投资、杠杆交易和风险对冲领域备受关注。2021年Archegos资本因TRS交易爆仓导致百亿美元级市场震荡,凸显了TRS系统设计的关键性。本文将从技术实现角度,解析TRS交…...
基于SpringBoot的高校体育馆场地预约管理系统-项目分享
基于SpringBoot的高校体育馆场地预约管理系统-项目分享 项目介绍项目摘要目录总体功能图用户实体图赛事实体图项目预览用户个人中心医生信息管理用户管理场地信息管理登录 最后 项目介绍 使用者:管理员 开发技术:MySQLJavaSpringBootVue 项目摘要 随着…...
MMIO、IOMAP 和 IOMMU 总结
MMIO、IOMAP 和 IOMMU 全面解析 📌 本文将深入浅出地梳理 Linux 驱动开发中常见的三大术语:MMIO、iomap、IOMMU。它们看似相似,其实职责完全不同,是理解 SoC 系统架构、DMA 安全性和驱动开发的基础。 一、MMIO(Memory-…...
Vscode开发STM32标准库
Vscode开发STM32 文章目录 引用一、文档介绍二、实际操作(基于标准库)总结 使用VScode开发STM32(keil),基础江科大标准库的串口接收和发送。 引用 VSCodeEIDE开发STM32,支持标准库、HAL库、LL库,可以在VSCode里进行调…...
Lateral 查询详解:概念、适用场景与普通 JOIN 的区别
1. 什么是Lateral查询? Lateral查询(也称为横向关联查询)是一种特殊的子查询,允许子查询中引用外层查询的列(即关联引用),并在执行时逐行对外层查询的每一行数据执行子查询。 语法上通常使用关…...
智能视频监控平台EasyCVR常见安防监控问题:录像机添加摄像头后无画面是什么原因
在智能安防场景中,室外安防监控摄像头承担着保障区域安全的重任,但画面无法显示、显示异常等问题却时常干扰正常监控工作,按照以下系统化步骤,即可高效定位并解决问题,让监控系统迅速恢复稳定运行。 一般出现这个问题…...
【Spring】深入解析 Spring AOP 核心概念:切点、连接点、通知、切面、通知类型和使用 @PointCut 定义切点的方法
Spring AOP 下面我们再来详细学习 AOP,主要是以下几部分: Spring AOP 核心概念 切点(Pointcut) 切点(Pointcut),也称之为“切入点”。 Pointcut 的作用就是提供一组规则(使用 Aspe…...
Uniapp:view容器(容器布局)
目录 一、基本概述二、属性说明三、常用布局3.1 横向布局3.2 纵向布局3.3 更多布局3.3.1 纵向布局-自动宽度3.3.2 纵向布局-固定宽度3.3.3 横向布局-自动宽度3.3.4 横向布局-居中3.3.5 横向布局-居右3.3.6 横向布局-平均分布3.3.7 横向布局-两端对齐3.3.8 横向布局-自动填充3.3…...
C# 运算符:?.(null 条件运算符)和 ??(null 合并运算符)
在 WinForms 中,comboBox1.SelectedValue?.ToString() ?? "" 这行代码使用了两个特殊的 C# 运算符:?.(null 条件运算符)和 ??(null 合并运算符)。让我分别解释它们的作用: ?.&…...
java/python——两个行为(操作)满足原子性的实现
目录 JAVA方法 1:使用 synchronized 同步块示例代码 方法 2:使用 ReentrantLock锁示例代码 方法 3:使用 AtomicReference 或其他原子类示例代码 方法 4:使用数据库事务(如果涉及数据库操作)示例代码&#x…...
SpringBoot中配置文件的加载顺序
下面的优先级由高到低 命令行参数java系统属性java系统环境变量外部config文件夹的application-{profile}.ym文件外部的application-{profile}.ym文件内部config文件夹的application-{profile}.ym文件内部的application-{profile}.ym文件外部config文件夹的application.ym文件外…...
Nginx下搭建rtmp流媒体服务 并使用HLS或者OBS测试
所需下载地址: 通过网盘分享的文件:rtmp 链接: https://pan.baidu.com/s/1t21J7cOzQR1ASLrsmrYshA?pwd0000 提取码: 0000 window: 解压 win目录下的 nginx-rtmp-module-1.2.2.zip和nginx 1.7.11.3 Gryphon.zip安装包,解压时选…...
在线查看【免费】 txt, xml(渲染), md(渲染), java, php, py, js, css 文件格式网站
可以免费在线查看 .docx/wps/Office/wmf/ psd/ psd/eml/epub/dwg, dxf/ txt/zip, rar/ jpg/mp3 m.gszh.xyz m.gszh.xyz 免费支持以下格式文件在线查看类型 支持 doc, docx, xls, xlsx, xlsm, ppt, pptx, csv, tsv, dotm, xlt, xltm, dot, dotx, xlam, xla, pages 等 Office 办…...
RIP动态路由(三层交换机+单臂路由)
RIP动态路由(三层交换机单臂路由) J1 (配置VLAN,修改端口) Switch>en Switch>en Switch# Switch#conf t Enter configuration commands, one per line. End with CNTL/Z. Switch(config)#int f0/1 Switch(config-if)#sw Switch(confi…...
Docker 基本概念与安装指南
Docker 基本概念与安装指南 一、Docker 核心概念 1. 容器(Container) 容器是 Docker 的核心运行单元,本质是一个轻量级的沙盒环境。它基于镜像创建,包含应用程序及其运行所需的依赖(如代码、库、环境变量等…...
Oracle DBA培训一般多长时间?
Oracle DBA培训的时间通常在2个月到6个月之间,具体看课程类型和你的学习目标。不过别只看总时长,关键得看每天学什么、练什么——有些机构把时间拖到半年,结果全是理论;有些课程压缩到2个月,但全是干货。下面分情况…...
【回眸】Linux 内核 (十七) 之 网络编程
前言 努力赶紧把Linux内核的内容更新完。 网络编程 协议的部分已经很成熟,只需要调用即可。 进程间通讯无法进行多机通信,网络通讯则解决了这一缺陷。 TCP/UDP协议对比 (1)TCP 面向连接(如打电话要先拨号建立连接…...
Batch Size
1. 什么是Batch Size? Batch Size(批大小)是指在深度学习模型训练过程中,每次前向传播和反向传播时输入到模型中的样本数量。具体来说,深度学习模型的训练通常基于梯度下降(Gradient Descent)算…...
Maven插件管理的基本原理
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
flutter 专题 六十三 Flutter入门与实战作者:xiangzhihong8Fluter 应用调试
Fluter 应用调试 Flutter 构建模式 目前,Flutter一共提供了三种运行模式,分别是Debug、Release和Profile模式。其中,Debug模式主要用在软件编写过程中,Release模式主要用于应用发布过程中,而Profile模式则主要用于应…...
MySQL-存储过程--游标
存储过程 游标 什么是游标 一个游标是一个SQL语句执行时系统内存创建的一个临时工作区域。一个游标包含一个查询语句的信息和它操作的数据行的信息。 mysql游标的特点 只读: 无法通过游标更新基础表中的数据不可滚动: 只能根据select中确定的顺序来…...
Spring AOP 事务
目录 一,引入依赖: 二,切面 1,基本概念 2, 通知类型: 3,Pointcut 4, 切面优先级: 5 ,自定义优先级Order 6,切点表达式 7, 自定义注解 总结: AOP有几种创建方式 三, Spring AOP原理 1, 代理模式 (1)静态代理 (2)动态代理 △JDK动态代理 △CGLIB动态代理 JDB和c…...
Itext进行PDF的编辑开发
这周写了一周的需求,是制作一个PDF生成功能,其中用到了Itext来制作PDF的视觉效果。其中一些功能不是很懂,仅作记录,若要学习请仔细甄别正确与否。 开始之前,我还是想说,这傻福需求怎么想出来的,…...
Python 中消费者 - 生产者模式详解
目录 引言 消费者 - 生产者模式原理 示例场景 Python 实现消费者 - 生产者模式 使用队列(Queue)实现 代码解释 使用协程实现 代码解释 应用场景 总结 引言 在软件开发里,消费者 - 生产者模式是一种常见且重要的设计模式。这种模式让…...
基于Hadoop的音乐推荐系统(源码+lw+部署文档+讲解),源码可白嫖!
摘要 本毕业生数据分析与可视化系统采用B/S架构,数据库是MySQL,网站的搭建与开发采用了先进的Java语言、爬虫技术进行编写,使用了Spring Boot框架。该系统从两个对象:由管理员和用户来对系统进行设计构建。主要功能包括ÿ…...
移动端动态滑动拨盘选择器【Axure元件库】
模拟移动端底部对话框效果,制作的年份、日期滑动拨盘选择器,支持日期动态滑动选择,提升原型制作强度。 该模板主要使用中继器、动态面板和矩形制作,使用简单,复用性强。只需对中继器数据表格中的数据项进行修改、增删…...
7. 深入Spring AI:刨析 Advisors 机制
目录 1、序言2、什么是Advisor?3、源码分析Advisor3.1、Advisor接口3.2、Advisor Ordered3.3、CallAroundAdvisor & StreamAroundAdvisor3.4、BaseAdvisor4、内置的Advisor类型4.1、MessageChatMemoryAdvisor4.2、PromptChatMemoryAdvisor4.3、VectorStoreChatMemoryAdvis…...
高保真动态项目管理图表集
本作品为项目管理图表类原型,以关系图谱、甘特图、流程图、泳道图为核心,提供基础的图表设计风格和交互案例,再进阶到高级的动态交互设计,由浅入深诠释Axure设计高端复杂的动态交互设计的魅力。 作品介绍 原型名称:Ax…...
MCP:AI时代的“万能插座”,开启大模型无限可能
摘要:Model Context Protocol(MCP)由Anthropic在2024年底开源,旨在统一大模型与外部工具、数据源的通信标准。采用客户端-服务器架构,基于JSON-RPC 2.0协议,支持stdio、SSE、Streamable HTTP等多种通信方式…...
IDEA打不开、打开报错
目录 场景异常原因解决 场景 1、本机已经安装了IDEA 2、再次安装另外一个版本的IDEA后打不开、打开报错 异常 这里忘记截图了。。。 原因 情况1-打不开:在同一台电脑安装多个IDEA是需要对idea的配置文件进行调整的,否则打不开 情况2-打开报错&#…...
TM1640学习手册及示例代码
数据手册 TM1640数据手册 数据手册解读 这里我们看管脚定义DIN和SCLK,一个数据线一个时钟线 SEG1~SEG8为段码,GRID1~GRID16为位码(共阴极情况下) 这里VDD给5V 数据指令 数据命令设置 地址命令设置 显示控制命令 共阴极硬件连接图…...
动态规划-零钱兑换
332.零钱兑换 给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。你可以认为每种硬币的数量是无…...
leetcode50.pow(x,n)
class Solution {private double f(double x,long n){if(n0)return 1.0;else {double tempf(x,n/2);return n%21?temp*temp*x:temp*temp;}}public double myPow(double x, int n) {long Nn;return n>0?f(x,N):1.0/f(x,-N);} }...
ECA 注意力机制:让你的卷积神经网络更上一层楼
ECA 注意力机制:让你的卷积神经网络更上一层楼 在深度学习领域,注意力机制已经成为提升模型性能的重要手段。从自注意力(Self-Attention)到各种变体,研究人员不断探索更高效、更有效的注意方法。今天我们要介绍一种轻…...
《谷歌Gemini 1.5:长语境理解重塑文档分析与检索新格局》
在人工智能的快速发展进程中,大语言模型不断突破边界,为各个领域带来变革性影响。谷歌Gemini 1.5的问世,凭借其卓越的长语境理解能力,在文档分析和检索任务方面掀起了一阵技术革新的浪潮。 以往的大语言模型在处理长文本时&#…...
量变与质变的辩证关系
量变和质变是唯物辩证法中揭示事物发展状态和形式的一对重要范畴,二者之间存在着密切的辩证关系。 一、量变是质变的必要准备 含义 量变是指事物数量的增减和场所的变更,是一种渐进的、不显著的变化。例如,水的温度升高,从0℃逐…...
讯联桌面TV版apk下载-讯联桌面安卓电视版免费下载安装教程
在智能电视的使用过程中,一款好用的桌面应用能极大提升我们的使用体验。讯联桌面 TV 版就是这样一款备受关注的应用,它可以让安卓电视拥有更个性化、便捷的操作界面。今天,就为大家详细介绍讯联桌面 TV 版 apk 的免费下载安装教程。 一、下载…...
【Vue】组件基础
目录 🚀 Vue 非单文件组件 和 单文件组件 的区别与实践对比 ✨ 引言 一、非单文件组件 1. 基本使用 2. 注意: 3. 组件的嵌套 4. 关于VueComponent: 5. 一个重要的内置关系(有点难理解) 二、 单文件组件 那就…...
OpenCV---图像预处理(四)
OpenCV—图像预处理(四) 文章目录 OpenCV---图像预处理(四)九,图像掩膜9.1 制作掩膜9.2 与运算9.3 颜色替换9.3.19.3.2 颜色替换 十,ROI切割十 一,图像添加水印11.1模板输入11.2 与运算11.3 图像…...
《MySQL:MySQL表的基本查询操作CRUD》
CRUD:Create(创建)、Retrieve(读取)、Update(更新)、Delete(删除)。 Create into 可以省略。 插入否则更新 由于主键或唯一键冲突而导致插入失败。 可以选择性的进行同步…...
Psychology 101 期末测验(附答案)
欢呼 啦啦啦~啦啦啦~♪(^∇^*) 终于考过啦~ 开心(*^▽^*) 撒花✿✿ヽ(▽)ノ✿ |必须晒下证书: 判卷 记录下判卷,还是错了几道,填空题2道压根填不上。惭愧~ 答案我隐藏了,实在想不出答案的朋友可以留言,不定时回复。 建议还是认认真真的学习~认认真真的考试~,知识就…...
Linux:权限相关问题
文章目录 shell命令以及运行的原理Linux权限 shell命令以及运行的原理 操作系统分为内核和外壳程序,xshell是外壳程序,外壳程序包括我们windows桌面上的图形化界面,本质都是翻译给核心处理,再显示出来,而我们输入的命令…...