当前位置: 首页 > news >正文

python数据分析(六):Pandas 多数据操作全面指南

Pandas 多数据操作全面指南:Merge, Join, Concatenate 与 Compare

1. 引言

在数据分析工作中,我们经常需要处理多个数据集并将它们以各种方式组合起来。Pandas 提供了多种强大的多数据操作方法,包括合并(merge)、连接(join)、连接(concatenate)和比较(compare)等。本文将详细介绍这些功能,并通过实际代码示例展示如何使用它们。

2. 数据合并 (Merge)

2.1 基本合并操作

merge() 是 Pandas 中最常用的数据合并方法,类似于 SQL 中的 JOIN 操作。

import pandas as pd# 创建两个示例DataFrame
df1 = pd.DataFrame({'key': ['A', 'B', 'C', 'D'],'value': [1, 2, 3, 4]})df2 = pd.DataFrame({'key': ['B', 'D', 'E', 'F'],'value': [5, 6, 7, 8]})# 内连接(inner join)
result = pd.merge(df1, df2, on='key')
print("Inner Join:\n", result)

输出

Inner Join:key  value_x  value_y
0   B        2        5
1   D        4        6

解释

  • on='key' 指定了合并的键
  • 默认是内连接(inner join),只保留两个DataFrame中都有的键
  • 自动为相同列名添加后缀 _x_y

2.2 不同类型的连接

# 左连接(left join)
result = pd.merge(df1, df2, on='key', how='left')
print("\nLeft Join:\n", result)# 右连接(right join)
result = pd.merge(df1, df2, on='key', how='right')
print("\nRight Join:\n", result)# 外连接(full outer join)
result = pd.merge(df1, df2, on='key', how='outer')
print("\nOuter Join:\n", result)

输出

Left Join:key  value_x  value_y
0   A        1      NaN
1   B        2      5.0
2   C        3      NaN
3   D        4      6.0Right Join:key  value_x  value_y
0   B      2.0        5
1   D      4.0        6
2   E      NaN        7
3   F      NaN        8Outer Join:key  value_x  value_y
0   A      1.0      NaN
1   B      2.0      5.0
2   C      3.0      NaN
3   D      4.0      6.0
4   E      NaN      7.0
5   F      NaN      8.0

解释

  • how 参数控制连接类型:‘left’, ‘right’, ‘outer’, ‘inner’
  • 缺失值用 NaN 填充

2.3 多键合并

# 创建含有多个键的DataFrame
df3 = pd.DataFrame({'key1': ['A', 'B', 'C', 'D'],'key2': ['W', 'X', 'Y', 'Z'],'value': [1, 2, 3, 4]})df4 = pd.DataFrame({'key1': ['B', 'D', 'E', 'F'],'key2': ['X', 'Z', 'Y', 'W'],'value': [5, 6, 7, 8]})# 多键合并
result = pd.merge(df3, df4, on=['key1', 'key2'])
print("\nMulti-key Merge:\n", result)

输出

Multi-key Merge:key1 key2  value_x  value_y
0    B    X        2        5
1    D    Z        4        6

3. 数据连接 (Join)

3.1 DataFrame的join方法

join()merge() 的便捷方法,默认按索引连接。

# 设置索引
df1.set_index('key', inplace=True)
df2.set_index('key', inplace=True)# 使用join连接
result = df1.join(df2, lsuffix='_left', rsuffix='_right')
print("\nJoin on Index:\n", result)

输出

Join on Index:value_left  value_right
key                          
A           1.0          NaN
B           2.0          5.0
C           3.0          NaN
D           4.0          6.0

解释

  • 默认是左连接
  • 必须指定 lsuffixrsuffix 来处理列名冲突
  • 按索引连接而不是列

3.2 按列连接

# 重置索引
df1.reset_index(inplace=True)
df2.reset_index(inplace=True)# 按列连接
result = df1.set_index('key').join(df2.set_index('key'), how='outer', lsuffix='_left', rsuffix='_right')
print("\nJoin on Column:\n", result)

4. 数据连接 (Concatenate)

4.1 基本连接操作

concat() 用于沿特定轴连接多个DataFrame或Series。

# 创建示例DataFrame
df5 = pd.DataFrame({'A': ['A0', 'A1', 'A2'],'B': ['B0', 'B1', 'B2']},index=[0, 1, 2])df6 = pd.DataFrame({'A': ['A3', 'A4', 'A5'],'B': ['B3', 'B4', 'B5']},index=[3, 4, 5])# 垂直连接(沿axis=0)
result = pd.concat([df5, df6])
print("\nVertical Concatenation:\n", result)# 水平连接(沿axis=1)
result = pd.concat([df5, df6], axis=1)
print("\nHorizontal Concatenation:\n", result)

输出

Vertical Concatenation:A   B
0  A0  B0
1  A1  B1
2  A2  B2
3  A3  B3
4  A4  B4
5  A5  B5Horizontal Concatenation:A   B    A    B
0  A0  B0  NaN  NaN
1  A1  B1  NaN  NaN
2  A2  B2  NaN  NaN
3  NaN  NaN  A3  B3
4  NaN  NaN  A4  B4
5  NaN  NaN  A5  B5

4.2 连接时处理索引

# 忽略原有索引
result = pd.concat([df5, df6], ignore_index=True)
print("\nConcatenation with Ignored Index:\n", result)# 添加多级索引
result = pd.concat([df5, df6], keys=['df5', 'df6'])
print("\nConcatenation with MultiIndex:\n", result)

5. 数据比较 (Compare)

5.1 比较两个DataFrame

Pandas 提供了多种比较DataFrame的方法。

# 创建两个相似但有差异的DataFrame
df7 = pd.DataFrame({'A': [1, 2, 3],'B': [4, 5, 6]})df8 = pd.DataFrame({'A': [1, 2, 4],'B': [4, 6, 6]})# 使用compare方法(需要Pandas 1.1.0+)
try:comparison = df7.compare(df8)print("\nDataFrame Comparison:\n", comparison)
except AttributeError:print("\ncompare() method requires pandas 1.1.0 or later")# 替代方法diff = df7 != df8print("\nDifference:\n", diff)

输出(如果使用compare方法):

DataFrame Comparison:A       B      self other self other
2  3.0   4.0  NaN   NaN
1  NaN   NaN  5.0   6.0

5.2 比较并标记差异

# 标记所有差异
def highlight_diff(data, color='yellow'):attr = f'background-color: {color}'other = data.xs('other', axis='columns', level=-1)self = data.xs('self', axis='columns', level=-1)return pd.DataFrame(np.where(self != other, attr, ''),index=data.index, columns=data.columns)comparison.style.apply(highlight_diff, axis=None)

6. 其他实用合并技巧

6.1 合并时处理重复列名

# 合并时有重复列名
df9 = pd.DataFrame({'key': ['A', 'B', 'C'],'value': [1, 2, 3]})df10 = pd.DataFrame({'key': ['B', 'C', 'D'],'value': [4, 5, 6]})result = pd.merge(df9, df10, on='key', suffixes=('_left', '_right'))
print("\nMerge with Suffixes:\n", result)

6.2 合并时验证关系

# 验证合并关系(确保是一对一、一对多或多对一)
try:result = pd.merge(df9, df10, on='key', validate='one_to_one')print("\nValidated Merge:\n", result)
except Exception as e:print("\nValidation Error:", e)

7. 性能考虑

7.1 合并大型DataFrame

# 创建大型DataFrame
import numpy as np
n = 1000000
big_df1 = pd.DataFrame({'key': np.random.randint(0, 10000, size=n),'value1': np.random.randn(n)})big_df2 = pd.DataFrame({'key': np.random.randint(0, 10000, size=n),'value2': np.random.randn(n)})# 比较合并方法的性能
%timeit pd.merge(big_df1, big_df2, on='key')
%timeit big_df1.merge(big_df2, on='key')

8. 总结

  1. merge() 是最灵活的数据合并方法,支持各种SQL风格的连接操作

    • 支持内连接、左连接、右连接和外连接
    • 可以处理多键合并和复杂的合并条件
  2. join() 是基于索引的合并便捷方法

    • 默认按索引连接
    • 语法比merge()更简洁但功能较少
  3. concat() 用于简单堆叠数据

    • 可以沿行(垂直)或列(水平)方向连接
    • 适合结构相同的数据集合并
  4. compare() 用于比较两个DataFrame的差异

    • 可以高亮显示差异
    • 需要Pandas 1.1.0及以上版本
  5. 性能考虑

    • 对于大型数据集,merge()通常比join()更快
    • 合并前适当设置索引可以提高性能

选择合适的多数据操作方法取决于:

  • 数据的大小和结构
  • 需要执行的连接类型
  • 是否需要保留所有数据或只保留匹配项

掌握这些多数据操作技术将大大提高你在实际数据分析工作中的效率和灵活性。

相关文章:

python数据分析(六):Pandas 多数据操作全面指南

Pandas 多数据操作全面指南:Merge, Join, Concatenate 与 Compare 1. 引言 在数据分析工作中,我们经常需要处理多个数据集并将它们以各种方式组合起来。Pandas 提供了多种强大的多数据操作方法,包括合并(merge)、连接(join)、连接(concaten…...

在K8S迁移节点kubelet数据存储目录

默认k8s节点kubelet数据目录在 /var/lib/kubelet,如果在部署前没有做好规划,其实默认就存储在系统盘/分区下了,这样会导致一个问题,如果数据量过大会导致kubelet服务异常,其次,系统盘下有一些系统服务引用&…...

k8s 学习记录 (六)_Pod 污点和容忍性详解

一、前言 在 Kubernetes 集群中,我们已经了解了节点亲和性和 Pod 亲和性,它们在 Pod 调度方面提供了很大的灵活性。今天,我们来探讨另外两个重要的概念 ——Pod 污点(Taints)和容忍性(Tolerations&#xf…...

hutools工具类中isNotEmpty与isNotBlank区分

基于以下两种情况。在判断的变量是String类型时, 判断是否为空,推荐使用isNotBlank(). 1. isNotEmpty 不会验证str中是否含有空字符串,而 isNotBlank方法会验证 public static boolean isNotEmpty(CharSequence str) {return false isEmpty…...

C#解析USB - HID手柄上摇杆按键数据

1. 了解相关知识 ​​HID设备通信原理​​:HID设备通过端点报告其状态和数据,设备通过报告描述符来描述数据用途,操作系统通过这个描述符了解设备发送数据的结构。通常一个完整的报告以特定的格式从设备传输至主机。​​Windows API函数​​…...

k8s术语pod

Pod概览 理解Pod Pod是kubernetes中你可以创建和部署的最小也是最简的单位,pod代表着集群中运行的进程。 Pod中封装着应用的容器(有的情况下是好几个容器),存储、独立的网络IP,管理容器如何运行的策略选项。Pod代表着部署的一个单位:kubemetes中应用的一个实例,可能由一个…...

使用高德MCP+AI编程工具打造一个旅游小助手

开始之前,我们先来回顾一下,什么是mcp MCP(Model Context Protocol) 模型上下文协议是 2024 年 11 月由 Anthropic 公司推出并开源的一个新标准 核心内容 架构2:MCP 采用客户端 - 服务器架构。AI 应用程序(如聊天工具或 IDE&a…...

AgeTravel | 银发文娱旅游一周新鲜事

银发文娱旅游一周新鲜事 整理 | AgeClub吕娆炜 一周银发文娱旅游产业资讯速览 星期一 4月28日 1 企业动态 携程老友会联合喜悦盛年,首发“旅游兴趣课堂”模式 华寿中心“这YOUNG的老年派”合作聚焦老龄文化需求 通用技术康养Q1营收同比增长129% 2 行业风向…...

【记】Laya2.x数字末尾导致换行异常问题

文章目录 图示 图示...

jspm老年体检信息管理系统(源码+lw+部署文档+讲解),源码可白嫖!

摘要 信息化时代,各行各业都以网络为基础飞速发展,而医疗服务行业的发展却进展缓慢,传统的医疗服务行业已经逐渐不满足民众的需求,有些还在以线下预约的方式接待病人,特别是针对于老年体检的服务,是少之又…...

point-cloud-annotation-tool工具windows复现,史诗巨制(windows 11)

point-cloud-annotation-tool 前期准备1.安装Qt52.安装Cmake3.安装VS 20194.编译构建 VTK 8.15.安装 PCL 1.86.编译Boost 软件环境适配准备1 Boost2 VTK 开始编译开始生成 前期准备 point-cloud-annotation-tool是一款三维标注软件,本次介绍的是再windows11环境下安…...

欧拉计划 Project Euler60(素数对集合)题解

欧拉计划 Project Euler 60 题解 题干思路code 题干 思路 先欧拉筛预处理出素数&#xff0c;然后dfs&#xff0c;注意剪枝&#xff0c;不然太容易炸了 code //13 5197 5701 6733 8389 //26033 #include <bits/stdc.h>using namespace std;using ll long long;bool i…...

DeepSeek破界而来:重构大规模深度检索的算力与边界

深度检索技术革命&#xff1a;DeepSeek万亿参数框架如何突破实时召回率瓶颈 引言&#xff1a;当千亿参数遇见实时检索 在人工智能技术飞速发展的今天&#xff0c;超大规模语言模型已成为推动产业智能化的核心引擎。然而&#xff0c;随着模型参数量突破万亿级门槛&#xff0c;…...

自定义指令input中前面不能输入空格

vue3加el-input 封装自定义指令 utils/trim.ts import type { Directive, DirectiveBinding } from vue;const trim: Directive {mounted(el, binding: DirectiveBinding) {// 获取 el-input 的 DOM 节点const inputEl el.querySelector(input);if (!inputEl) {console.er…...

esp32将partitions.csv文件启用到工程项目中的配置

在ESP32项目里&#xff0c;partitions.csv 文件用于定义闪存的分区表&#xff0c;它规定了不同类型数据&#xff08;如代码、文件系统、OTA 分区等&#xff09;在闪存中的存储位置和大小。下面为你详细介绍如何将 partitions.csv 文件集成到工程项目中以及相应的配置步骤。 1.…...

Windows系统下,导入运行 RuoYi-Vue3 项目

基于SpringBootVue3前后端分离的Java快速开发框架 一、后端 1.git下载代码 RuoYi-Vue&#xff1a;RuoYi-Vue: 基于SpringBoot&#xff0c;Spring Security&#xff0c;JWT&#xff0c;Vue & Element 的前后端分离权限管理系统 git clone https://gitee.com/y_project/R…...

Spark 配置 YARN 模式

在大数据处理领域&#xff0c;Spark 是一个强大的分布式计算框架&#xff0c;而 YARN&#xff08;Yet Another Resource Negotiator&#xff09;则是 Hadoop 生态系统中出色的资源管理器。将 Spark 配置为 YARN 模式&#xff0c;可以充分利用 YARN 高效的资源管理和调度能力&am…...

【Linux学习笔记】进程替换和自定义shell

【Linux学习笔记】进程替换和自定义shell &#x1f525;个人主页&#xff1a;大白的编程日记 &#x1f525;专栏&#xff1a;Linux学习笔记 文章目录 【Linux学习笔记】进程替换和自定义shell前言一.进程程序替换1.1 替换原理1.2 替换函数1.2.1函数解释1.2.2命名理解 二.自主…...

HarmonyOS运动开发:如何监听用户运动步数数据

前言 在开发运动类应用时,准确地监听和记录用户的运动步数是一项关键功能。HarmonyOS 提供了强大的传感器框架,使得开发者能够轻松地获取设备的运动数据。本文将深入探讨如何在 HarmonyOS 应用中实现步数监听功能,同时分享一些开发过程中的经验和技巧,帮助你更好地理解和实…...

Vuex状态管理及其持久化使用指南

1. 安装 Vuex Vue 2 或 Vue 3 项目&#xff1a; npm install vuex4 # Vuex 4 兼容 Vue 2 和 Vue 3 2. 创建 Store 新建 store/index.js&#xff1a; import { createStore } from vuex; import createPersistedState from vuex-persistedstate; // 持久化插件// 定义子模…...

k8s学习笔记

1查看默认命名空间pod kubectl get nodes 查看所有名空间的pod kubectl get pods -A 查看所有节点node kubectl get nodes 2根据配置文件,给集群创建资源 kubectl apply -f xxxx.yaml 3查看集群部署了哪些应用? kubectl get pods -A 4生成、删除、获取所…...

HarmonyOS ArkUI安全控件开发指南:粘贴、保存与位置控件的实现与隐私保护实践

目录 安全控件1. 粘贴控件1.1 约束与限制1.2 开发步骤 2. 保存控件2.1 约束与限制2.2 开发步骤 3. 位置控件3.1 约束与限制3.2 开发步骤 安全控件 安全控件是系统提供的一组系统实现的ArkUI组件&#xff0c;其中保存控件在用户首次使用时&#xff0c;会弹出通知弹窗&#xff0…...

前端在平常的开发中高度还原ui图的思考规范

问题原因 我们明明按照ui测量 为什么还会出现这么多样式偏差 根据我多次的验收反馈总结如下 使用组件库 不可能所以样式覆盖复制粘贴以前的代码 样式产生偏差有些样式是继承所得 难免疏漏图片等背景问题 或者切图问题padding等结尾问题 解决方案 组件库穿透 主要样式复制粘…...

Python 数据智能实战 (2):LLM 工具箱搭建 - API/库实操与高效 Prompt 设计入门

写在前面 —— 工欲善其事,必先利其器:连接你的 Python 与 LLM 大脑,掌握“对话”的艺术 本篇博客,我们将聚焦于“工欲善其事,必先利其器”这一核心环节,带你完成以下关键任务: 选择你的 LLM “接入点”: 了解访问 LLM 的主要方式 (云 API vs. 本地模型),并为入门选…...

即时设计笔记

1. 编辑形状 1.1 连接两个锚点 如图&#xff0c;形状编辑模式下&#xff0c;想将下面图形变成闭合形状 使用【钢笔工具】选中其中一锚点&#xff0c;会自动伸出一条线&#xff0c;然后再点击另一个锚点即可 【注意】&#xff0c;形状闭合后&#xff0c;会发现无法填充颜色&am…...

“云大物智移”背景下,五年制高职计算机类高水平专业群建设方案

在信息技术革命的浪潮中&#xff0c;云计算、大数据、物联网、人工智能和移动互联网&#xff08;简称“云大物智移”&#xff09;已成为推动全球经济和社会数字化转型的关键力量。这些技术不仅重塑了产业格局&#xff0c;也给职业教育带来了前所未有的挑战与机遇。随着“云大物…...

docker desktop汉化

关闭Docker Desktop 在Docker安装目录找到app.asar文件并将其备份&#xff0c;防止出现意外。 Windows下默认为C:\Program Files\Docker\Docker\frontend\resourcesMacos下默认为/Applications/Docker.app/Contents/MacOS/Docker Desktop.app/Contents/ResourcesUbuntu/Debian…...

KUKA机器人快速启动设置

KUKA机器人在首次开机启动时&#xff0c;有时在示教器上需要进行投入运行等相关的设置。如以下相关的信息需要处理&#xff1a; 1、机器人系统开机后&#xff0c;选择T1运行模式&#xff1b;2、显示提示信息&#xff1a;“RDC 存储器和控制系统不一致什么被更换了”时&#xf…...

【Java学习】Java的CGLIB动态代理:通俗解释与使用指南

应友友的要求&#xff0c;本章是对于Java的CGLIB动态代理进行一个通俗的解释&#xff0c;希望能够帮助到奋斗的你&#xff0c;一起加油&#xff01;&#xff01;&#xff01; &#x1f31f; 通俗理解CGLIB动态代理 想象你有一个玩具机器人&#xff08;原始类&#xff09;&…...

Python3 基础语法

编码 默认情况下&#xff0c;Python3 源码文件以 UTF-8 编码&#xff0c;所有字符串都是 unicode 字符串。 当然你也可以为源码文件指定不同的编码&#xff1a; # -*- coding: cp-1252 -*- 上述定义允许在源文件中使用 Windows-1252 字符集中的字符编码&#xff0c;对应适合…...

基于Lucene的多场景检索系统开发指南

基于Lucene的多场景检索系统开发指南 官网 https://lucene.apache.org/ 一、项目构建配置 (pom.xml) <dependencies><!-- Lucene核心库 --><dependency><groupId>org.apache.lucene</groupId><artifactId>lucene-core</artifactId&g…...

SDC命令详解:使用get_nets命令进行查询

相关阅读 SDC命令详解https://blog.csdn.net/weixin_45791458/category_12931432.html?spm1001.2014.3001.5482 get_nets命令用于创建一个线网对象集合&#xff0c;关于设计对象和集合的更详细介绍&#xff0c;可以参考下面的博客。需要注意的是&#xff0c;在有些工具中还存…...

MATLAB长方体磁体3D磁力线生成

代码说明&#xff1a; 磁体参数设置&#xff1a;对磁体的尺寸、磁化强度以及真空磁导率进行定义。计算网格生成&#xff1a;构建一个 3D 网格&#xff0c;同时排除磁体内部的点。磁场计算&#xff1a;采用等效面磁荷法来计算每个网格点的磁场。可视化&#xff1a; 绘制磁体的框…...

东土科技NewPre系列智能控制器的创新之旅

物流行业&#xff0c;作为支撑现代供应链的核心环节&#xff0c;正在面临效率瓶颈、人工成本上升、设备协同难等多重挑战。如何实现从自动化向智能化的转型&#xff0c;成为行业亟须解决的关键问题。东土科技基于NewPre3102智能控制器打造的工业AI智能机器人控制系统&#xff0…...

2025年燃气从业人员考试题库及答案

一、单选题 83.城镇燃气输配管道严密性试验稳压的持续时间应为24h&#xff0c;每小时记录不应少于1次&#xff0c;当修正压力降小于_____Pa为合格。&#xff08;&#xff09; A.100 B.133 C.150 D.200 答案&#xff1a;B 84.室外钢管敷设描述错误的是_____。&#xff08;…...

小结: 接口类型和路由优先级

网络接口类型 1. Bridge-if&#xff08;桥接接口&#xff09; 作用&#xff1a;用于桥接网络&#xff0c;将多个接口或VLAN连接为一个广播域&#xff0c;实现二层数据转发。 常用指令&#xff1a; interface bridge-if <number> bridge <bridge-id> # 将接口加入…...

【XR空间传送】深入理解Unity中 XR Interaction Toolkit 的 MatchOrientation 用法与使用场景(空间传送、视角切换)

一、前言 在 Unity 进行 VR/AR 开发&#xff0c;尤其是在展示、环境体验、导览交互等场景中&#xff0c;“传送&#xff08;Teleport&#xff09;”是一项非常核心的操作。它不仅决定了玩家的位置&#xff0c;还直接影响玩家的站姿、视角与空间感知。 在 Unity 官方提供的 XR…...

PPT/WORD如何实现Shift键加鼠标滚轮实现左右滑动

方法&#xff1a;使用【AutoHotKey】软件 1. 什么是AutoHotKey&#xff1f; AutoHotKey (AHK)&#xff0c;是一款类似于按键精灵的软件&#xff0c;用于自动化控制键盘和鼠标&#xff0c;提高工作效率。 官网下载&#xff1a;https://www.autohotkey.com/ 2. 需求背景 在编…...

C++函数模板基础

1 函数模板 1.1 基础介绍 函数模板是一种特殊的函数定义,它允许你创建通用的函数,这些函数可以处理多种不同的数据类型,而不需要为每种数据类型都编写一个单独的函数。 在 C++ 里,函数模板的格式包含模板声明与函数定义两部分,其基本格式如下: template <typename…...

Java实现使用EasyExcel按模板导出文件

需求&#xff1a;导出excel文件要求头部标题内容过于复杂&#xff0c;在代码层面不好实现&#xff0c;直接提供模板&#xff0c;只需要将数据写入即可。 一、代码实现示例 实现数据写入模板代码如下&#xff1a; public void export(HttpServletResponse response) throws E…...

【AI】OrinNX上安装RIVA-2.19.0,实现文本转语音

1、注册NGC账户 1)登录官网注册, https://ngc.nvidia.com/signin 2)生成key 3)拷贝生成的key到文本中,下面会使用 2、安装NGC工具 目前最新版本为3.64.2 1)下载 wget --content-disposition https://api.ngc.nvidia.com/v2/resources/nvidia/ngc-apps/ngc_cli/vers…...

Ansible安装配置

一、前提 服务器操作系统均为centos7.9 主机ipmaster(Ansible管理端)172.25.192.2node1172.25.192.10node2172.25.192.3 更新/etc/hosts文件 二、安装 master节点&#xff1a; 1. 安装epel源 yum install -y epel-release 2. 安装Ansible yum install -y ansible A…...

认识Linux基本操作、命令

目录 一、了解一下用户目录、linux根目录 二、常见的linux命令 &#xff08;1&#xff09;目录切换 cd【与windows通用】 &#xff08;2&#xff09; 查看文件列 ls &#xff08;3&#xff09;打开文件权限-chmod ux *.sh &#xff08;4&#xff09;查看当前所在路径 pwd…...

Android学习总结之Bitmap篇

一、质量压缩&#xff08;面试高频&#xff1a;原理与适用场景&#xff09; 1. 核心原理&#xff08;面试官必问&#xff09; 质量压缩针对有损压缩格式&#xff08;如 JPEG&#xff09;&#xff0c;通过丢弃图像中人类视觉不敏感的高频信息&#xff08;如色彩过渡细节&#…...

MySQL--数据引擎详解

存储引擎 MySQL体系结构 连接层&#xff1a; 主要接收客户端的连接&#xff0c;然后完成一些链接的处理&#xff0c;以及认证授权的相关操作和安全方案&#xff0c;还要去检查是否超过最大连接数等等&#xff0c;比如在连接MySQL服务器时需要输入用户名&#xff0c;密码&#…...

高瓴资本张磊的顶级价值投资之道

高瓴资本张磊的顶级价值投资之道 一、核心理念&#xff1a;长期主义与动态价值创造 张磊的价值投资体系以“长期主义”为基石&#xff0c;结合中国产业升级特点&#xff0c;形成了独特的投资哲学&#xff1a; 时间维度重构 • 主张跨越经济周期&#xff0c;关注企业10年以上的价…...

JAVA使用Apache POI导出Word,支持向表格动态添加多行数据

JAVA使用Apache POI动态导出Word文档_java导出word文档-CSDN博客...

外部存储器接口:EMIF总线

作为嵌入式系统中的关键接口之一&#xff0c;EMIF&#xff08;External Memory Interface&#xff0c;外部存储器接口&#xff09; 是处理器与外部存储器或外设进行高速数据交换的核心总线。以下从工作原理、信号定义、配置方式到设计要点进行系统化解析&#xff1a; 一、EMIF的…...

四.割草机技术总结--4.基站发送给流动站的差分数据传输标准RTCM

四.割草机技术总结–4.基站发送给流动站的差分数据传输标准RTCM 文章目录 四.割草机技术总结--4.基站发送给流动站的差分数据传输标准RTCM4.0 RTCM差分标准4.1 **什么是RTCM?**4.1.1**>版本1**4.1.2**>版本2**4.1.3**>版本3**4.2**为什么RTK的固件升级很重要?**4.3参…...

openssl_error_string() 不要依赖错误信息作为逻辑判断

不应该将 OpenSSL 错误信息直接用于程序的逻辑控制&#xff0c;而是应该将其作为调试和记录的辅助手段。这是因为 OpenSSL 错误信息的格式和内容可能会因 OpenSSL 版本、操作系统环境等因素而发生变化&#xff0c;直接依赖这些信息可能会导致代码的不稳定和难以维护。 为什么不…...