Python怎么使用Pandas库_Pandas数据处理入门指南

Pandas数据清洗常用技巧包括处理缺失值、重复值、异常值、文本数据、日期时间及数据标准化。具体为:用dropna()或fillna()处理缺失值;drop_duplicates()去除重复数据;通过IQR或标准差识别异常值并合理处理;利用str方法清洗文本,如去空格、大小写转换;用to_datetime统一日期格式;结合业务需求进行数据归一化。同时需注意链式赋值警告、性能优化和内存管理等最佳实践。

python怎么使用pandas库_pandas数据处理入门指南

Pandas是Python数据科学领域的一把瑞士军刀,它提供了一系列高效的数据结构和数据分析工具,让你能轻松处理和分析表格型数据,就像在用一个超级强大的Excel。无论是数据清洗、转换、聚合还是探索性分析,Pandas都能提供直观且高性能的解决方案。

解决方案

要开始使用Pandas,第一步通常是导入它,约定俗成地使用

pd

作为别名。

import pandas as pdimport numpy as np # 经常和Pandas一起使用

1. 创建数据结构:DataFrame和Series

Pandas最核心的两个数据结构是DataFrame和Series。Series可以看作带标签的一维数组,而DataFrame则是一个二维的、表格型数据结构,每列可以有不同的数据类型。

立即学习“Python免费学习笔记(深入)”;

创建Series:

s = pd.Series([1, 3, 5, np.nan, 6, 8])print(s)# 输出:# 0    1.0# 1    3.0# 2    5.0# 3    NaN# 4    6.0# 5    8.0# dtype: float64

创建DataFrame,这通常是我们日常工作中打交道最多的。可以从字典、列表的列表,或者直接从CSV、Excel文件加载。

# 从字典创建DataFramedata = {    '姓名': ['张三', '李四', '王五', '赵六'],    '年龄': [25, 30, 28, 35],    '城市': ['北京', '上海', '广州', '深圳'],    '薪资': [8000, 12000, 9000, 15000]}df = pd.DataFrame(data)print(df)# 输出:#   姓名  年龄  城市    薪资# 0  张三  25  北京   8000# 1  李四  30  上海  12000# 2  王五  28  广州   9000# 3  赵六  35  深圳  15000

2. 从文件加载数据

真实世界的数据很少是手动输入的,更多是从文件读取。Pandas对多种文件格式提供了强大的支持。

# 读取CSV文件# df_csv = pd.read_csv('your_data.csv')# 读取Excel文件# df_excel = pd.read_excel('your_data.xlsx', sheet_name='Sheet1')# 读取JSON文件# df_json = pd.read_json('your_data.json')

通常,

pd.read_csv()

是最常用的函数,因为它能处理各种分隔符、编码问题。

3. 数据查看与初步探索

拿到数据后,第一件事是看看它长什么样。

print(df.head()) # 查看前5行print(df.tail(3)) # 查看后3行print(df.info()) # 查看数据概览,包括列名、非空值数量、数据类型print(df.describe()) # 对数值列进行统计描述,如均值、标准差、最大最小值等print(df.shape) # 查看行数和列数 (rows, columns)print(df.columns) # 查看所有列名

4. 数据选择与过滤

这是数据分析的基础操作,如何精准地取出你想要的数据。

选择单列或多列:

print(df['姓名']) # 选择单列,返回Seriesprint(df[['姓名', '薪资']]) # 选择多列,返回DataFrame

使用

loc

iloc

进行行和列的选择:

loc

:基于标签(列名、行索引)选择。

iloc

:基于整数位置选择。

print(df.loc[0]) # 选择第一行print(df.loc[0, '姓名']) # 选择第一行'姓名'列的值print(df.loc[0:2, ['姓名', '年龄']]) # 选择0到2行(包含2),'姓名'和'年龄'列print(df.iloc[0:3, 0:2]) # 选择前3行,前2列(基于位置)

条件过滤:

# 筛选年龄大于30的员工older_employees = df[df['年龄'] > 30]print(older_employees)# 筛选城市是上海且薪资高于10000的员工filtered_df = df[(df['城市'] == '上海') & (df['薪资'] > 10000)]print(filtered_df)

5. 数据清洗与处理

这是数据分析中最耗时也最关键的一步。

缺失值处理:

# 检查缺失值print(df.isnull().sum())# 删除含有缺失值的行# df_cleaned = df.dropna()# 填充缺失值# df_filled = df.fillna(value=0) # 用0填充所有缺失值# df['年龄'].fillna(df['年龄'].mean(), inplace=True) # 用年龄均值填充年龄列的缺失值

数据类型转换:

# 将某一列转换为特定类型# df['年龄'] = df['年龄'].astype(int)

重复值处理:

# 检查重复行# print(df.duplicated().sum())# 删除重复行# df_no_duplicates = df.drop_duplicates()

6. 数据聚合与分组

groupby()

是Pandas中最强大的功能之一,它允许你按照一个或多个列对数据进行分组,然后对每个组执行聚合操作(如求和、均值、计数等)。

# 按照城市分组,计算每个城市的平均薪资avg_salary_by_city = df.groupby('城市')['薪资'].mean()print(avg_salary_by_city)# 按照城市和年龄分组,计算每个组的薪资总和grouped_data = df.groupby(['城市', '年龄'])['薪资'].sum()print(grouped_data)# 可以同时应用多个聚合函数agg_data = df.groupby('城市')['薪资'].agg(['mean', 'max', 'min', 'count'])print(agg_data)

7. 数据合并与连接

当数据分散在多个DataFrame中时,你需要将它们合并起来。

df1 = pd.DataFrame({'key': ['A', 'B', 'C', 'D'], 'value': np.random.randn(4)})df2 = pd.DataFrame({'key': ['B', 'D', 'E', 'F'], 'value2': np.random.randn(4)})# 内连接:只保留两个DataFrame中key都存在的行merged_df = pd.merge(df1, df2, on='key', how='inner')print(merged_df)# 左连接:保留左边DataFrame的所有行,匹配右边DataFrame的行left_merged_df = pd.merge(df1, df2, on='key', how='left')print(left_merged_df)# 拼接(Stacking):将多个DataFrame按行或列堆叠起来df3 = pd.DataFrame({'key': ['G', 'H'], 'value': np.random.randn(2)})concatenated_df = pd.concat([df1, df3], ignore_index=True)print(concatenated_df)

Pandas数据清洗的常用技巧有哪些?

数据清洗,这活儿说起来简单,做起来往往是整个项目最磨人的部分。我的经验是,没有哪个数据集是“干净”的,总有些奇奇怪怪的脏数据等着你去处理。Pandas在这方面提供了很多趁手的工具。

除了前面提到的缺失值、重复值处理,还有几个点我觉得特别重要:

异常值检测与处理: 异常值可能是数据录入错误,也可能代表了真实的特殊情况。识别它们是第一步。常用的方法有基于统计(如3倍标准差、IQR范围)或可视化(箱线图、散点图)。Pandas本身没有直接的异常值检测函数,但你可以结合其统计功能轻松实现。

# 假设我们想找出薪资的异常值Q1 = df['薪资'].quantile(0.25)Q3 = df['薪资'].quantile(0.75)IQR = Q3 - Q1lower_bound = Q1 - 1.5 * IQRupper_bound = Q3 + 1.5 * IQRoutliers = df[(df['薪资']  upper_bound)]print("薪资异常值:n", outliers)# 处理方式可以是删除、替换为均值/中位数,或者上限/下限值# df['薪资'] = np.where(df['薪资'] > upper_bound, upper_bound, df['薪资'])

处理异常值需要谨慎,有时它们是宝贵的信息,比如高价值客户或系统故障。

文本数据清洗: 字符串列往往是最混乱的。大小写不一致、多余空格、特殊字符、错别字……这些都得处理。Pandas的

str

访问器非常强大。

df['城市'] = df['城市'].str.strip() # 移除前后空格df['城市'] = df['城市'].str.lower() # 转换为小写df['姓名'] = df['姓名'].str.replace('张', 'ZHANG') # 替换字符# 使用正则表达式进行更复杂的匹配和替换# df['描述'] = df['描述'].str.replace(r'[^ws]', '', regex=True) # 移除所有非字母数字和空格的字符

这里面有个小坑,如果你的字符串列里有

NaN

,直接调用

str

方法会报错,需要先填充或过滤掉缺失值。

日期时间数据处理 日期时间格式不统一是常态。Pandas的

to_datetime

函数能智能地解析多种日期时间格式。

# df['日期'] = pd.to_datetime(df['日期'], errors='coerce') # errors='coerce'会将无法解析的日期转换为NaT(Not a Time)# 提取年份、月份、星期几等# df['年份'] = df['日期'].dt.year# df['月份'] = df['日期'].dt.month

处理日期时间时,时区问题也常常让人头疼,特别是在处理跨国数据时。Pandas提供了

tz_localize

tz_convert

来处理这些。

数据标准化/归一化: 在进行机器学习前,往往需要将不同量纲的数值特征进行缩放。虽然这通常在Pandas之外(如scikit-learn)完成,但Pandas是数据准备的平台。

# 简单的Min-Max标准化示例# df['薪资_normalized'] = (df['薪资'] - df['薪资'].min()) / (df['薪资'].max() - df['薪资'].min())

这些技巧,用得多了自然熟练,但每次遇到新数据,我还是会先花大量时间在清洗上,毕竟“垃圾进,垃圾出”是数据分析的铁律。

Pandas如何进行数据聚合和分组分析?

数据聚合和分组分析是Pandas的灵魂所在,它允许我们从宏观角度理解数据,而不是纠结于每一行。

groupby()

方法就是实现这一点的核心。

想象一下,你有一堆销售数据,你可能想知道每个产品类别的总销售额,或者每个地区的平均订单价值。这就是

groupby()

的用武之地。

基本流程是:Split-Apply-Combine

Split(拆分):根据一个或多个键(列)将DataFrame拆分成若干个组。Apply(应用):对每个组独立地应用一个函数(聚合、转换或过滤)。Combine(组合):将所有组的结果组合成一个新的DataFrame或Series。

最常见的应用是聚合函数:

# 假设我们有一个更复杂的销售数据sales_data = {    '产品类别': ['电子', '服装', '电子', '食品', '服装', '电子', '食品'],    '地区': ['华东', '华南', '华东', '华北', '华南', '华东', '华北'],    '销售额': [1200, 500, 1500, 300, 800, 1000, 450],    '订单数量': [10, 5, 12, 3, 8, 9, 4]}sales_df = pd.DataFrame(sales_data)print("原始销售数据:n", sales_df)# 按产品类别计算总销售额total_sales_by_category = sales_df.groupby('产品类别')['销售额'].sum()print("n按产品类别总销售额:n", total_sales_by_category)# 按地区计算平均订单数量avg_orders_by_region = sales_df.groupby('地区')['订单数量'].mean()print("n按地区平均订单数量:n", avg_orders_by_region)

更进一步,你可以同时对多个列应用不同的聚合函数,使用

agg()

方法:

# 按产品类别和地区分组,同时计算销售额的总和、平均值和订单数量的总和multi_agg = sales_df.groupby(['产品类别', '地区']).agg(    总销售额=('销售额', 'sum'),    平均销售额=('销售额', 'mean'),    总订单数量=('订单数量', 'sum'))print("n多重聚合结果:n", multi_agg)

这里我用了Python 3.6+的f-string风格的

agg

语法,它让输出的列名更清晰,我个人觉得比传入字典的旧方式更直观。

除了聚合,

groupby()

还可以用于转换(transform)过滤(filter)

transform:对每个组应用一个函数,但返回的结果与原始DataFrame的索引对齐,常用于填充组内缺失值或进行组内标准化。

# 计算每个产品类别销售额占该类别总销售额的比例sales_df['类别销售额占比'] = sales_df.groupby('产品类别')['销售额'].transform(lambda x: x / x.sum())print("n带类别销售额占比的数据:n", sales_df)

filter:根据组的某些特性来筛选组。

# 筛选出总销售额超过2000的产品类别filtered_categories = sales_df.groupby('产品类别').filter(lambda x: x['销售额'].sum() > 2000)print("n总销售额超过2000的产品类别数据:n", filtered_categories)

这些高级用法让

groupby()

变得极其灵活,能解决很多复杂的数据分析问题。我发现很多人刚开始用Pandas时,经常会尝试用循环来解决分组问题,但一旦掌握了

groupby()

,效率会提升好几个数量级。

Pandas在实际项目中常见的陷阱与最佳实践?

在实际项目中使用Pandas,我遇到过不少坑,也总结了一些经验。它确实强大,但用不好也容易“翻车”。

常见陷阱:

链式赋值警告(SettingWithCopyWarning): 这是新手最常遇到的问题之一。当你对一个DataFrame的“视图”进行修改时,Pandas会发出警告。

# 错误示例:可能引发SettingWithCopyWarning# df_subset = df[df['年龄'] > 30]# df_subset['薪资'] = df_subset['薪资'] * 1.1 # 这里的修改可能不会反映到原始df,也可能报错

最佳实践: 明确地使用

.loc

.copy()

。如果你想创建一个独立的DataFrame副本,就用

.copy()

;如果想在原始DataFrame上修改,且操作是基于条件选择的,就用

.loc

df_subset = df[df['年龄'] > 30].copy() # 明确复制一份df_subset['薪资'] = df_subset['薪资'] * 1.1# 在原始DataFrame上修改,使用.locdf.loc[df['年龄'] > 30, '薪资'] = df.loc[df['年龄'] > 30, '薪资'] * 1.1

这个坑我踩过好几次,导致数据修改没生效,或者莫名其妙的错误。

性能问题: 对大型数据集使用循环(

for

循环、

apply

配合lambda函数)往往效率低下。

# 性能差的示例:逐行处理# for index, row in df.iterrows():#     df.loc[index, '新列'] = row['列A'] + row['列B']

最佳实践: 尽可能使用Pandas的向量化操作。Pandas底层是C语言实现的,向量化操作能充分利用CPU的并行计算能力。

df['新列'] = df['列A'] + df['列B'] # 向量化操作

如果必须使用

apply

,尽量用在Series上,或者确保你的函数是高度优化的。对于非常复杂的操作,考虑使用

df.apply(..., axis=1)

,但要清楚这通常比向量化慢。更极致的性能需求,可以考虑

numba

modin

内存占用: 大数据集可能导致内存不足。特别是字符串和日期时间列,它们在Pandas中可能比你想象的更占用内存。最佳实践:

选择合适的数据类型: 对于整数或浮点数,使用

int8

,

int16

,

float32

等更小的类型。

df.info(memory_usage='deep')

可以查看详细内存占用。Categorical类型: 对于重复值较多的字符串列(如国家、城市),转换为

category

类型可以显著节省内存。

df['城市'] = df['城市'].astype('category')

分块读取: 对于超大型文件,使用

pd.read_csv(..., chunksize=...)

分块读取和处理数据。

索引管理不当: 索引是Pandas的强大之处,但如果处理不当,也可能导致问题,比如合并时索引不匹配。最佳实践:

在合并或拼接DataFrame时,明确指定

on

参数,或者在不需要索引时使用

reset_index()

。如果索引有实际意义(如时间序列),充分利用它进行时间序列操作。

这些陷阱,说到底都是对Pandas底层机制理解不够深入造成的。多实践,多看官方文档,你会发现Pandas的设计哲学非常精妙。它不是一个简单的工具库,而是一个强大的数据处理框架,值得我们花时间去深入学习。

以上就是Python怎么使用Pandas库_Pandas数据处理入门指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1368999.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Python中数组如何操作 Python中数组操作教程
上一篇 2025年12月14日 09:15:52
解决Python函数嵌套中的递归错误与UI计算逻辑优化
下一篇 2025年12月14日 09:16:06

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 修复Django电商项目中AJAX过滤产品列表图片不显示问题

    在Django电商项目中,当使用AJAX动态加载过滤后的产品列表时,常遇到图片无法正常显示的问题。这通常是由于前端模板中图片加载方式(如data-setbg属性结合JavaScript库)与AJAX动态内容更新机制不兼容所致。解决方案是直接在AJAX返回的HTML中使用标准的标签来渲染图片,确保浏览…

    2026年5月10日
    000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • Debian syslog性能优化技巧有哪些

    提升Debian系统syslog (通常基于rsyslog)性能,关键在于精简配置和高效处理日志。以下策略能有效优化日志管理,提升系统整体性能: 精简配置,高效加载: 在rsyslog配置文件中,仅加载必要的输入、输出和解析模块。 使用全局指令设置日志级别和格式,避免不必要的处理。 自定义模板: 创…

    2026年5月10日
    000
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • Golang gRPC流式请求异常处理

    在Golang的gRPC流式通信中,必须通过context.Context处理异常。应监听上下文取消或超时,及时释放资源,设置合理超时,避免连接长时间挂起,并在goroutine中通过context控制生命周期。 在使用 Golang 和 gRPC 实现流式通信时,异常处理是确保服务健壮性的关键部分…

    2026年5月10日
    000
  • Go语言mgo查询构建:深入理解bson.M与日期范围查询的正确实践

    本文旨在解决go语言mgo库中构建复杂查询时,特别是涉及嵌套`bson.m`和日期范围筛选的常见错误。我们将深入剖析`bson.m`的类型特性,解释为何直接索引`interface{}`会导致“invalid operation”错误,并提供一种推荐的、结构清晰的代码重构方案,以确保查询条件能够正确…

    2026年5月10日
    100
  • vscode上怎么运行html_vscode上运行html步骤【指南】

    首先保存文件为.html格式,再通过浏览器或Live Server插件打开预览;推荐安装Live Server实现本地服务器运行与实时刷新,提升开发体验。 在 VS Code 上运行 HTML 文件并不需要复杂的配置,只需几个简单步骤即可预览页面效果。VS Code 本身是一个代码编辑器,不直接运行…

    2026年5月10日
    100
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • 如何在HTML中插入表单元素_HTML表单控件与输入类型使用指南

    HTML表单通过标签构建,包含action和method属性定义数据提交目标与方式,常用input类型如text、password、email等适配不同输入需求,配合label、required、placeholder提升可用性,结合textarea、select、button等控件实现完整交互,是…

    2026年5月10日
    100
  • 前端缓存策略与JavaScript存储管理

    根据数据特性选择合适的存储方式并制定清晰的读写与清理逻辑,能显著提升前端性能;合理运用Cookie、localStorage、sessionStorage、IndexedDB及Cache API,结合缓存策略与定期清理机制,可在保证用户体验的同时避免安全与性能隐患。 前端缓存和JavaScript存…

    2026年5月10日
    200
  • 网站标题关键词更新后,搜索引擎为何仍显示旧标题?

    网站标题更新后,搜索引擎为何显示旧标题? 网站SEO优化中,站长常修改网站标题关键词,期望搜索结果显示自定义标题。然而,即使更新标签、meta keywords、meta description和结构化数据中的name属性后,搜索结果仍显示旧标题,这令人费解。本文将对此进行解释。 问题:站长修改了网…

    2026年5月10日
    100
  • HTML5网页如何实现手势操作 HTML5网页移动端交互的处理技巧

    首先利用原生touch事件实现滑动判断,再通过preventDefault解决滚动冲突,接着引入Hammer.js处理复杂手势,最后通过优化点击区域、避免事件冲突和增加视觉反馈提升体验。 在移动端浏览器中,HTML5网页可以通过触摸事件实现手势操作,提升用户体验。虽然原生JavaScript提供了基…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信