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

Pandas 数据处理-排序与排名的深度探索【第69篇—python:文本数据处理】

文章目录

  • Pandas 数据处理-排序与排名的深度探索
    • 1. sort_index方法
    • 2. sort_values方法
    • 3. rank方法
    • 4. 多列排序
    • 5. 排名方法的参数详解
    • 6. 处理重复值
    • 7. 对索引进行排名
    • 8. 多级索引排序与排名
    • 9. 更高级的排序自定义
    • 10. 性能优化技巧
      • 10.1 使用`nsmallest`和`nlargest`
      • 10.2 使用`sort_values`的`inplace`参数
      • 10.3 使用`merge`进行排名
  • 总结

Pandas 数据处理-排序与排名的深度探索

Pandas是Python中广泛使用的数据处理库,提供了丰富的功能来处理和分析数据。在数据分析过程中,经常需要对数据进行排序和排名,以便更好地理解和分析数据。本文将介绍Pandas中常用的排序、排名方法,包括sort_indexsort_valuesrank,并通过代码实例和解析来演示它们的使用。

image-20240208150118873

1. sort_index方法

sort_index方法主要用于按照索引进行排序。默认情况下,它会按照索引的升序进行排序,但也可以通过参数指定降序排列。下面是一个简单的例子:

import pandas as pd# 创建一个DataFrame
data = {'Name': ['Alice', 'Bob', 'Charlie', 'David'],'Age': [25, 30, 22, 35],'Score': [85, 90, 75, 95]}df = pd.DataFrame(data, index=[3, 1, 4, 2])# 使用sort_index进行升序排序
df_sorted = df.sort_index()
print("按照索引升序排序:\n", df_sorted)# 使用sort_index进行降序排序
df_sorted_desc = df.sort_index(ascending=False)
print("按照索引降序排序:\n", df_sorted_desc)

在上面的例子中,sort_index方法根据索引进行了升序和降序排序。

image-20240208150134866

2. sort_values方法

sort_values方法用于按照指定列的值进行排序。可以通过by参数指定排序的列,也可以通过ascending参数指定升序或降序。以下是一个示例:

# 使用sort_values按照Age列的值进行升序排序
df_age_sorted = df.sort_values(by='Age')
print("按照Age列升序排序:\n", df_age_sorted)# 使用sort_values按照Score列的值进行降序排序
df_score_sorted_desc = df.sort_values(by='Score', ascending=False)
print("按照Score列降序排序:\n", df_score_sorted_desc)

在上面的例子中,sort_values方法分别根据"Age"列进行升序排序和根据"Score"列进行降序排序。

image-20240208150151961

3. rank方法

rank方法用于为数据分配排名。默认情况下,它根据数值大小进行排名,具有相同数值的元素将分配相同的排名,且排名取平均值。以下是一个例子:

# 使用rank方法为Age列分配排名
df['Age_Rank'] = df['Age'].rank()
print("根据Age列分配排名:\n", df)

在上面的例子中,rank方法为"Age"列分配了排名,并将结果添加到DataFrame中的新列"Age_Rank"中。

通过以上代码实例,我们展示了Pandas中常用的排序、排名方法。这些方法在数据分析和处理中起着重要作用,帮助我们更好地理解和利用数据。阅读本文后,你应该能够灵活运用这些方法来满足不同数据处理的需求。

4. 多列排序

在实际数据分析中,经常需要根据多列的值进行排序。Pandas中,可以通过传递包含多个列名的列表来实现多列排序。以下是一个例子:

# 使用sort_values按照Score列升序、Age列降序排序
df_multi_sorted = df.sort_values(by=['Score', 'Age'], ascending=[True, False])
print("按照Score列升序、Age列降序排序:\n", df_multi_sorted)

在上述例子中,sort_values方法根据"Score"列进行升序排序,然后在"Score"列相同的情况下,根据"Age"列进行降序排序。

5. 排名方法的参数详解

rank方法具有一些可选参数,可以根据实际需求进行调整。以下是一些常用的参数:

  • method: 指定处理相同值时的方法,默认为"average",表示取平均值。其他可选值包括"min"、“max”、"first"和"dense"等。
  • ascending: 指定排名的升序或降序,默认为True(升序)。
  • na_option: 指定对缺失值的处理方式,默认为"keep",表示保留缺失值;可以设置为"top"或"bottom",表示将缺失值分别排在最前或最后。
# 使用rank方法,设置method和na_option参数
df['Score_Rank'] = df['Score'].rank(method='min', ascending=False, na_option='top')
print("根据Score列分配排名,使用min方法和top参数:\n", df)

在上面的例子中,rank方法使用了"min"方法,即相同值取最小排名,同时将缺失值排在最前。

通过这些参数的合理运用,我们可以更灵活地控制排名方法的行为,以适应不同的数据情况。

6. 处理重复值

在数据集中,可能存在重复的行,而sort_values方法也可以用于处理重复值。通过duplicateskeep参数,我们可以灵活地选择如何处理重复的行。

# 创建含有重复值的DataFrame
data_with_duplicates = {'Name': ['Alice', 'Bob', 'Charlie', 'David', 'Alice'],'Age': [25, 30, 22, 35, 25],'Score': [85, 90, 75, 95, 85]}df_duplicates = pd.DataFrame(data_with_duplicates)# 使用sort_values处理重复值
df_no_duplicates = df_duplicates.sort_values(by=['Name', 'Age'], keep='first')
print("处理重复值后的DataFrame:\n", df_no_duplicates)

在上述例子中,sort_values方法根据"Name"列和"Age"列排序,并通过keep='first'保留第一次出现的重复行,删除后续的重复行。

7. 对索引进行排名

除了对列进行排序和排名,Pandas也支持对索引进行排序和排名。这对于处理时间序列数据等场景非常有用。

# 对索引进行排序
df_index_sorted = df.sort_index(ascending=False)
print("对索引降序排序:\n", df_index_sorted)# 使用rank方法为索引分配排名
df['Index_Rank'] = df.index.rank()
print("对索引进行排名:\n", df)

在上述例子中,sort_index方法用于对索引进行排序,而rank方法则用于为索引分配排名。

8. 多级索引排序与排名

Pandas支持多级索引,这在处理复杂层次化数据时非常有用。我们可以使用sort_index方法对多级索引进行排序,以及使用rank方法进行排名。

# 创建具有多级索引的DataFrame
index_data = [('Group1', 'A'), ('Group1', 'B'), ('Group2', 'A'), ('Group2', 'B')]
multi_index = pd.MultiIndex.from_tuples(index_data, names=['Group', 'Subgroup'])data_multi_index = {'Age': [25, 30, 22, 35],'Score': [85, 90, 75, 95]}df_multi_index = pd.DataFrame(data_multi_index, index=multi_index)# 对多级索引进行排序
df_multi_sorted = df_multi_index.sort_index(level=['Group', 'Subgroup'], ascending=[True, False])
print("对多级索引排序:\n", df_multi_sorted)# 使用rank方法为多级索引分配排名
df_multi_index['Rank'] = df_multi_index.groupby('Group')['Score'].rank(ascending=False)
print("对多级索引进行排名:\n", df_multi_index)

在上述例子中,sort_index方法根据多级索引中"Group"和"Subgroup"的层级进行排序,而rank方法使用groupby对多级索引的"Group"进行分组,然后为每组内的"Score"列进行排名。

image-20240208150232126

9. 更高级的排序自定义

有时,我们可能需要更高级的排序自定义,例如根据自定义函数或条件进行排序。在这种情况下,可以使用key参数。

# 创建一个DataFrame
data_custom_sort = {'Name': ['Alice', 'Bob', 'Charlie', 'David'],'Age': [25, 30, 22, 35],'Score': [85, 90, 75, 95]}df_custom_sort = pd.DataFrame(data_custom_sort)# 使用sort_values自定义排序规则
df_custom_sorted = df_custom_sort.sort_values(by='Age', key=lambda x: x % 2)
print("根据Age列进行奇偶排序:\n", df_custom_sorted)

在上述例子中,sort_values方法通过key参数,根据"Age"列的奇偶性进行排序。

10. 性能优化技巧

在处理大规模数据集时,性能优化变得尤为重要。在Pandas中,一些技巧可以帮助提高排序和排名的执行效率。

10.1 使用nsmallestnlargest

如果只需要获取最小或最大的几行数据,可以使用nsmallestnlargest方法,它们比完整的排序更高效。

# 使用nsmallest获取Age列最小的两行数据
df_nsmallest = df.nsmallest(2, 'Age')
print("Age列最小的两行数据:\n", df_nsmallest)

10.2 使用sort_valuesinplace参数

当对数据进行排序时,可以使用inplace=True参数来直接修改原始DataFrame,而不是创建一个新的排序后的副本。

# 使用sort_values对Score列进行升序排序,直接修改原始DataFrame
df.sort_values(by='Score', inplace=True)
print("原始DataFrame经过Score列升序排序:\n", df)

10.3 使用merge进行排名

对于需要根据其他列的值进行排名的情况,可以使用merge方法结合rank来提高性能。

# 创建一个DataFrame用于排名
rank_df = pd.DataFrame({'Name': ['Alice', 'Bob', 'Charlie', 'David'],'Rank_Score': [4, 3, 2, 1]})# 使用merge将排名合并到原始DataFrame
df_merged = pd.merge(df, rank_df, on='Name')
print("将排名合并到原始DataFrame:\n", df_merged)

通过这些性能优化技巧,可以在处理大规模数据时更加高效地进行排序和排名操作,提升代码执行速度。

image-20240208150257753

总结

在本篇技术博客中,我们深入研究了Pandas中的排序和排名方法,包括sort_indexsort_valuesrank。通过具体的代码实例和解析,我们详细介绍了这些方法的使用方式,使读者能够更好地理解和应用于实际的数据处理场景。

首先,我们学习了如何使用sort_index方法按照索引对数据进行排序,以及如何控制升序和降序排列。接着,我们探讨了sort_values方法,演示了根据单列或多列的值进行排序的方式,并介绍了处理重复值的方法。在排名方面,我们通过rank方法展示了如何为数据分配排名,以及如何通过一些参数调整排名的行为。

进一步地,我们介绍了多级索引的排序与排名,展示了对复杂层次化数据的处理方法。此外,我们讨论了一些高级排序自定义的技巧,包括使用自定义函数进行排序。

在性能优化方面,我们提出了几种有效的技巧,例如使用nsmallestnlargest方法、sort_valuesinplace参数,以及通过merge方法进行排名。这些技巧有助于在处理大规模数据集时提高代码的执行效率。

总体而言,通过本文的学习,读者应该能够更灵活地运用Pandas中的排序和排名方法,从而在实际的数据分析工作中取得更好的效果。这些技能对于数据科学家、分析师和工程师来说都是非常宝贵的,能够帮助他们更高效、更准确地处理和分析数据。

相关文章:

Pandas 数据处理-排序与排名的深度探索【第69篇—python:文本数据处理】

文章目录 Pandas 数据处理-排序与排名的深度探索1. sort_index方法2. sort_values方法3. rank方法4. 多列排序5. 排名方法的参数详解6. 处理重复值7. 对索引进行排名8. 多级索引排序与排名9. 更高级的排序自定义10. 性能优化技巧10.1 使用nsmallest和nlargest10.2 使用sort_val…...

第8节、双电机多段直线运动【51单片机+L298N步进电机系列教程】

↑↑↑点击上方【目录】,查看本系列全部文章 摘要:前面章节主要介绍了bresenham直线插值运动,本节内容介绍让两个电机完成连续的直线运动,目标是画一个正五角星 一、五角星图介绍 五角星总共10条直线,10个顶点。设定左下角为原点…...

Elasticsearch:基本 CRUD 操作 - Python

在我之前的文章 “Elasticsearch:关于在 Python 中使用 Elasticsearch 你需要知道的一切 - 8.x”,我详细讲述了如何建立 Elasticsearch 的客户端连接。我们也详述了如何对数据的写入及一些基本操作。在今天的文章中,我们针对数据的 CRUD (cre…...

1992-2022年全国及31省对外开放度测算数据(含原始数据+计算结果)(无缺失)

1992-2022年全国及31省对外开放度测算数据(含原始数据计算结果)(无缺失) 1、时间:1992-2022年 2、来源:各省年鉴、国家统计局、统计公报、 3、指标:进出口总额(万美元&#xff09…...

JVM之GC垃圾回收

GC垃圾回收 如何判断对象可以回收 引用计数法 如果有对象引用计数加一,没有对象引用,计数减一,如果计数为零,则回收 但是如果存在循环引用,即A对象引用B对象,B对象引用A对象,会造成内存泄漏 可…...

自然语言学习nlp 六

https://www.bilibili.com/video/BV1UG411p7zv?p118 Delta Tuning,尤其是在自然语言处理(NLP)和机器学习领域中,通常指的是对预训练模型进行微调的一种策略。这种策略不是直接更新整个预训练模型的权重,而是仅针对模型…...

fpga 需要掌握哪些基础知识?

个人根据自己的一些心得总结一下fpga 需要掌握的基础知识,希望对你有帮助。 1、数电(必须掌握的基础),然后进阶学模电, 2、掌握HDL(verilog或VHDL)一般建议先学verilog,然后可以学…...

Qt未来市场洞察

跨平台开发:Qt作为一种跨平台的开发框架,具有良好的适应性和灵活性,未来将继续受到广泛应用。随着多设备和多平台应用的增加,Qt的前景在跨平台开发领域将更加广阔。 物联网应用:由于Qt对嵌入式系统和物联网应用的良好支…...

GPT-4模型中的token和Tokenization概念介绍

Token从字面意思上看是游戏代币,用在深度学习中的自然语言处理领域中时,代表着输入文字序列的“代币化”。那么海量语料中的文字序列,就可以转化为海量的代币,用来训练我们的模型。这样我们就能够理解“用于GPT-4训练的token数量大…...

宽字节注入漏洞原理以及修复方法

漏洞名称:宽字节注入 漏洞描述: 宽字节注入是相对于单字节注入而言的,该注入跟HTML页面编码无关,宽字节注入常见于mysql中,GB2312、GBK、GB18030、BIG5、Shift_JIS等这些都是常说的宽字节,实际上只有两字节。宽字节带来的安全问…...

【Linux】SystemV IPC

进程间通信 一、SystemV 共享内存1. 共享内存原理2. 系统调用接口(1)创建共享内存(2)形成 key(3)测试接口(4)关联进程(5)取消关联(6)释…...

iview 页面中判断溢出才使用Tooltip组件

使用方法 <TextTooltip :content"contentValue"></TextTooltip> 给Tooltip再包装一下 <template><Tooltip transfer :content"content" :theme"theme" :disabled"!showTooltip" :max-width"300" :p…...

如何使用websocket

如何使用websocket 之前看到过一个面试题&#xff1a;吃饭点餐的小程序里&#xff0c;同一桌的用户点餐菜单如何做到的实时同步&#xff1f; 答案就是&#xff1a;使用websocket使数据变动时服务端实时推送消息给其他用户。 最近在我们自己的项目中我也遇到了类似问题&#xf…...

C++ 调用lua 脚本

需求&#xff1a; 使用Qt/C 调用 lua 脚本 扩展原有功能。 步骤&#xff1a; 1&#xff0c;工程中引入 头文件&#xff0c;库文件。lua二进制下载地址&#xff08;Lua Binaries&#xff09; 2&#xff0c; 调用脚本内函数。 这里调用lua 脚本中的process函数&#xff0c;并…...

Centos 内存和硬盘占用情况以及top作用

目录 只查看内存使用情况&#xff1a; 内存使用排序取前5个&#xff1a; 硬盘占用情况 定位占用空间最大目录 top查看cpu及内存使用信息 前言-与正文无关 生活远不止眼前的苦劳与奔波&#xff0c;它还充满了无数值得我们去体验和珍惜的美好事物。在这个快节奏的世界中&…...

【数据结构】堆(创建,调整,插入,删除,运用)

目录 堆的概念&#xff1a; 堆的性质&#xff1a; 堆的存储方式&#xff1a; 堆的创建 &#xff1a; 堆的调整&#xff1a; 向下调整&#xff1a; 向上调整&#xff1a; 堆的创建&#xff1a; 建堆的时间复杂度&#xff1a; 向下调整&#xff1a; 向上调整&#xff…...

v-if 和v-for的联合规则及示例

第073个 查看专栏目录: VUE ------ element UI 专栏目标 在vue和element UI联合技术栈的操控下&#xff0c;本专栏提供行之有效的源代码示例和信息点介绍&#xff0c;做到灵活运用。 提供vue2的一些基本操作&#xff1a;安装、引用&#xff0c;模板使用&#xff0c;computed&a…...

各互联网企业测绘资质调研

公司子公司产品产品介绍资质获得资质时间阿里巴巴高德高德地图作为阿里的全资子公司&#xff0c;中国领先的数字地图内容、导航和位置服务解决方案提供商&#xff0c;互联网地图行业龙头&#xff0c;2021年4月高德实现全月平均日活跃用户数超过1亿的重要里程碑&#xff0c;稳居…...

C++自定义函数详解

个人主页&#xff1a;PingdiGuo_guo 收录专栏&#xff1a;C干货专栏 铁汁们新年好呀&#xff0c;今天我们来了解自定义函数。 文章目录 1.数学中的函数 2.什么是自定义函数 3.自定义函数如何使用&#xff1f; 4.值传递和引用传递&#xff08;形参和实参区分&#xff09; …...

flask+vue+python跨区通勤人员健康体检预约管理系统

跨区通勤人员健康管理系统设计的目的是为用户提供体检项目等功能。 与其它应用程序相比&#xff0c;跨区通勤人员健康的设计主要面向于跨区通勤人员&#xff0c;旨在为管理员和用户提供一个跨区通勤人员健康管理系统。用户可以通过系统及时查看体检预约等。 跨区通勤人员健康管…...

Spring Boot动态加载Jar包与动态配置技术探究

Spring Boot动态加载Jar包与动态配置技术探究 1. 引言 在当今快节奏的软件开发领域&#xff0c;高效的开发框架是保持竞争力的关键。Spring Boot作为一款快速开发框架&#xff0c;以其简化配置、内嵌Web服务器、强大的开发工具等特性&#xff0c;成为众多开发者的首选。其背后…...

Lua metatable metamethod

示例代码 《programming in lua》里有一个案例很详细&#xff0c;就是写一个集合类的table&#xff0c;其负责筛选出table中不重复的元素并组合成一个新的table。本人按照自己的方式默写了一次&#xff0c;结果发现大差不差&#xff0c;代码如下&#xff1a; Set {} --集合--…...

HCIA-HarmonyOS设备开发认证V2.0-3.2.轻量系统内核基础-任务管理

目录 一、任务管理1.1、任务状态1.2、任务基本概念1.3、任务管理使用说明1.4、任务开发流程1.5、任务管理接口 一、任务管理 从系统角度看&#xff0c;任务是竞争系统资源的最小运行单元。任务可以使用或等待CPU、使用内存空间等系统资源&#xff0c;并独立于其它任务运行。 O…...

中小型网络系统总体规划与设计方法

目录 1.基于网络的信息系统基本结构 2.网络需求调研与系统设计原则 3.网络用户调查 4.网络节点地理位置分布情况 5.网络需求详细分析 6.应用概要分析 7.网络工程设计总体目标与设计原则 8.网络结构与拓扑构型设计方法 9.核心层网络结构设计 10.接入核心路由器 11.汇聚…...

以管理员权限删除某文件夹

到开始菜单中找到—命令提示符—右击以管理员运行 使用&#xff1a;del /f /s /q “文件夹位置” 例&#xff1a;del /f /s /q "C:\Program Files (x86)\my_code\.git"...

JenkinsGitLab完成自动化构建部署

关于GitLab安装:GitLab安装-CSDN博客 Docker中安装GitLab:Docker下安装GitLab-CSDN博客 安装JenKins Jenkins官网:Jenkins 中文版:Jenkins 安装时候中文页面的war包下不来 在英文页面 记得装JDK8以上 JenKins使用java写的 运行JenKins需要JDK环境 我这里已经装好了 将下…...

JVM 性能调优 - 参数基础(2)

查看 JDK 版本 $ java -version java version "1.8.0_151" Java(TM) SE Runtime Environment (build 1.8.0_151-b12) Java HotSpot(TM) 64-Bit Server VM (build 25.151-b12, mixed mode) 查看 Java 帮助文档 $ java -help 用法: java [-options] class [args...] …...

大型软件编程实例分享,诊所门诊处方笺管理系统多台电脑同时使用的软件教程

大型软件编程实例分享&#xff0c;诊所门诊处方笺管理系统多台电脑同时使用的软件教程 一、前言 以下教程以 佳易王诊所门诊电子处方管理系统V17.2 为例说明 软件资源可以点击最下方官网卡片了解详情 软件左侧为导航栏 1、系统参数设置&#xff1a;可以设置打印等参数 2、…...

Java基于微信小程序的医院挂号系统

文章目录 1 简介2 技术栈3 系统目标3.2 系统功能需求分析3.2.1 功能需求分析 4 系统模块设计4.1 数据库模块设计 5 系统的实现5.1 微信小程序个人中心5.2 科**室内容查看的实现**5.3 预约挂号的实现5.4 后台管理界面实现5.5 医生预约管理5.6 医生信息管理 参考文献7 推荐阅读8 …...

你是在独立思考,还是在被洗脑?

你有过这样的经历吗&#xff1f; 老板走过来&#xff0c;急匆匆丢给你一句&#xff1a;帮我整理一下那个客户的资料&#xff0c;下午给我。你抬头&#xff0c;应道「好好好」。老板扬长而去。你转念一想&#xff1a; 等等&#xff0c;哪个客户&#xff1f;什么资料&#xff1f;…...

在django中集成markdown文本框

首先需要下载开源组件&#xff1a;http://editor.md.ipandao.com/&#xff0c;可能需要挂梯子。 百度网盘&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1D9o3P8EQDqSqfhAw10kYkw 提取码&#xff1a;eric 1.在html代码中生成一个div&#xff0c;ideditor <div c…...

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Slider组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之Slider组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Slider组件 滑动条组件&#xff0c;通常用于快速调节设置值&#xff0c;如音量调…...

django admin 自定义界面时丢失左侧导航 nav_sidebar

只显示了自定义模板的内容&#xff0c;左侧导航没有显示出来。 原因&#xff1a;context 漏掉了&#xff0c;要补上。 # 错误写法&#xff08;左侧导航不显示&#xff09;def changelist_view(self, request, extra_contextNone):form CsvImportForm()payload {"form&qu…...

JSP原理简述

JSP动态网页技术&#xff0c;可以定义html&#xff0c;css&#xff0c;js等静态内容&#xff0c;还可以定义java代码等动态内容。 注意导入坐标时&#xff0c;JSP的scope标签是provided&#xff0c;和servlet一样&#xff0c;否则会报错。 JSP本质上就是一个Servlet&#xff0c…...

C/C++ - 异常处理

目录 错误处理 异常处理 异常传播 异常规划 标准异常 自定异常 错误处理 在C语言中&#xff0c;错误通常通过函数的返回值来表示。 错误返回值 对于能返回特殊值&#xff08;如NULL或负值&#xff09;的函数&#xff0c;在调用时检查这些值来处理错误。 #include <st…...

十、项目开发总结报告(软件工程)

1&#xff0e;引言 1.1编写目的 1.2项目背景 1.3定义 1.4参考资料 2&#xff0e;开发结果 2.1产品 2.2主要功能及性能 2.3所用工时 2.4所用机时 2.5进度 2.6费用 3&#xff0e;评价 3.1生产率评价 3.2技术方案评价 3.3产品质量评价 4&#xff…...

在 VMware 虚拟机上安装 CentOS系统 完整(全图文)教程

一、前期准备&#xff1a; 1.安装VMware 虚拟机软件&#xff08;不在讲解&#xff0c;可自行去下载安装&#xff09;。官网&#xff1a;https://customerconnect.vmware.com/cn/downloads/details?downloadGroupWKST-PLAYER-1750&productId1377&rPId111471 2.下载iso…...

吉他学习:右手拨弦方法,右手拨弦训练 左手按弦方法

第六课 右手拨弦方法https://m.lizhiweike.com/lecture2/29362775 第七课 右手拨弦训练https://m.lizhiweike.com/lecture2/29362708...

【初识爬虫+requests模块】

爬虫又称网络蜘蛛、网络机器人。本质就是程序模拟人使用浏览器访问网站&#xff0c;并将需要的数据抓取下来。爬虫不仅能够使用在搜索引擎领域&#xff0c;在数据分析、商业领域都得到了大规模的应用。 URL 每一个URL指向一个资源&#xff0c;可以是一个html页面&#xff0c;一…...

微信小程序(三十八)滚动容器

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.滚动触底事件 2.下拉刷新事件 源码&#xff1a; index.wxml <view class"Area"> <!-- scroll-y 垂直滚动refresher-enabled 允许刷新bindrefresherrefresh 绑定刷新作用函数bindscrollto…...

Python学习之路-Tornado基础:数据库

Python学习之路-Tornado基础:数据库 简介 与Django框架相比&#xff0c;Tornado没有自带ORM&#xff0c;对于数据库需要自己去适配。我们使用MySQL数据库。 在Tornado3.0版本以前提供tornado.database模块用来操作MySQL数据库&#xff0c;而从3.0版本开始&#xff0c;此模块…...

Golang的for循环变量和goroutine的陷阱,1.22版本的更新

先来看一段golang 1.22版本之前的for循环的代码 package mainimport "fmt"func main() {done : make(chan bool)values : []string{"chen", "hai", "feng"}for _, v : range values {fmt.Println("start")go func() {fmt.P…...

List 差集

文章目录 基本类型对象类型 基本类型 ListUtils.subtract 方法用于计算两个集合的差集&#xff0c;即返回 list1 中有但 list2 中没有的元素。 其中&#xff0c;list1 指向第一个集合&#xff0c;list2 指向第二个集合。该方法返回一个新的 List 对象&#xff0c;它包含所有在…...

ArcGIS的UTM与高斯-克吕格投影分带要点总结

UTM&#xff08;通用横轴墨卡托投影、等角横轴割椭圆柱投影&#xff09;投影分带投影要点&#xff1a; 1&#xff09;UTM投影采用6度分带 2&#xff09;可根据公式计算&#xff0c;带数&#xff08;经度整数位/6&#xff09;的整数部分31 3&#xff09;北半球地区&#xff0…...

华为第二批难题一:基于预训练AI模型的元件库生成

我的理解&#xff1a;华为的这个难道应该是想通过大模型技术&#xff0c;识别元件手册上的图文内容&#xff0c;与现有建库工具结合&#xff0c;有潜力按标准生成各种库模型。 正好&#xff0c;我们正在研究&#xff0c;利用知识图谱技术快速生成装配模型&#xff0c;其中也涉…...

Android AOSP源码研究之万事开头难----经验教训记录

文章目录 1.概述2.Android源下载1.配置环境变量2.安装curl3.下载repo并授权4.创建一个文件夹保存源码5.设置repo的地址并配置为清华源6.初始化仓库7.指定我们需要下载的源码分支并初始化 2.1 使用移动硬盘存放Android源码的坑2.2 解决方法 3.Android源码编译4.Android源烧录 1.…...

动态数据源

一、部署 1、导入依赖 <dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>3.1.0</version></dependency>2、编写yml 配置文件 spring:datasource:dyna…...

2024.1.29力扣每日一题——自由之路

2024.1.29 题目来源我的题解方法一 动态规划 题目来源 力扣每日一题&#xff1b;题序&#xff1a;514 我的题解 方法一 动态规划 定义 dp[i][j] 表示从前往后拼写出 key的第 i个字符&#xff0c; ring 的第 j个字符与 12:00 方向对齐的最少步数&#xff08;下标均从 0 开始&…...

Qt应用软件【协议篇】UDP示例

UDP协议简介 UDP(用户数据报协议)是一种无连接的网络协议,提供了简单但是不可靠的消息传输服务。与TCP不同,UDP不保证数据包的顺序、重复性或者可达性,但它在速度和效率上具有优势,特别适合那些对实时性要求高的应用,如视频流、在线游戏等。 Qt中的UDP编程 在Qt中,U…...

MyBatis之动态代理实现增删改查以及MyBatis-config.xml中读取DB信息文件和SQL中JavaBean别名配置

MyBatis之环境搭建以及实现增删改查 前言实现步骤1. 编写MyBatis-config.xml配置文件2. 编写Mapper.xml文件&#xff08;增删改查SQL文&#xff09;3. 定义PeronMapper接口4. 编写测试类1. 执行步骤2. 代码实例3. 运行log 开发环境构造图总结 前言 上一篇文章&#xff0c;我们…...