大数据新视界 --大数据大厂之数据清洗工具 OpenRefine 实战:清理与转换数据

       💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的博客,正是这样一个温暖美好的所在。在这里,你们不仅能够收获既富有趣味又极为实用的内容知识,还可以毫无拘束地畅所欲言,尽情分享自己独特的见解。我真诚地期待着你们的到来,愿我们能在这片小小的天地里共同成长,共同进步。💖💖💖

在这里插入图片描述

本博客的精华专栏:

  1. 大数据新视界专栏系列:聚焦大数据,展技术应用,推动进步拓展新视野。
  2. Java 大厂面试专栏系列:提供大厂面试的相关技巧和经验,助力求职。
  3. Python 魅力之旅:探索数据与智能的奥秘专栏系列:走进 Python 的精彩天地,感受数据处理与智能应用的独特魅力。
  4. Java 性能优化传奇之旅:铸就编程巅峰之路:如一把神奇钥匙,深度开启 JVM 等关键领域之门。丰富案例似璀璨繁星,引领你踏上编程巅峰的壮丽征程。
  5. Java 虚拟机(JVM)专栏系列:深入剖析 JVM 的工作原理和优化方法。
  6. Java 技术栈专栏系列:全面涵盖 Java 相关的各种技术。
  7. Java 学习路线专栏系列:为不同阶段的学习者规划清晰的学习路径。
  8. JVM万亿性能密码:在数字世界的浩瀚星海中,JVM 如神秘宝藏,其万亿性能密码即将开启奇幻之旅。
  9. AI(人工智能)专栏系列:紧跟科技潮流,介绍人工智能的应用和发展趋势。
  10. 数据库核心宝典:构建强大数据体系专栏系列:专栏涵盖关系与非关系数据库及相关技术,助力构建强大数据体系。
  11. 大前端风云榜:引领技术浪潮专栏系列:大前端专栏如风云榜,捕捉 Vue.js、React Native 等重要技术动态,引领你在技术浪潮中前行。
  12. 工具秘籍专栏系列:工具助力,开发如有神。
           展望未来,我将持续深入钻研前沿技术,及时推出如人工智能和大数据等相关专题内容。同时,我会努力打造更加活跃的社区氛围,举办技术挑战活动和代码分享会,激发大家的学习热情与创造力。我也会加强与读者的互动,依据大家的反馈不断优化博客的内容和功能。此外,我还会积极拓展合作渠道,与优秀的博主和技术机构携手合作,为大家带来更为丰富的学习资源和机会。
           我热切期待能与你们一同在这个小小的网络世界里探索、学习、成长你们的每一次点赞、关注、评论、打赏和订阅专栏,都是对我最大的支持。让我们一起在知识的海洋中尽情遨游,共同打造一个充满活力与智慧的博客社区。✨✨✨
           衷心地感谢每一位为我点赞、给予关注、留下真诚留言以及慷慨打赏的朋友,还有那些满怀热忱订阅我专栏的坚定支持者。你们的每一次互动,都犹如强劲的动力,推动着我不断向前迈进。倘若大家对更多精彩内容充满期待,欢迎加入【青云交社区】或加微信:【QingYunJiao】【备注:分享交流】。让我们携手并肩,一同踏上知识的广袤天地,去尽情探索。此刻,请立即访问我的主页吧,那里有更多的惊喜在等待着你。相信通过我们齐心协力的共同努力,这里必将化身为一座知识的璀璨宝库,吸引更多热爱学习、渴望进步的伙伴们纷纷加入,共同开启这一趟意义非凡的探索之旅,驶向知识的浩瀚海洋。让我们众志成城,在未来必定能够汇聚更多志同道合之人,携手共创知识领域的辉煌篇章

大数据新视界 --大数据大厂之数据清洗工具 OpenRefine 实战:清理与转换数据

  • 引言:
  • 正文:
    • 一、OpenRefine 的概述
      • 1.1 什么是 OpenRefine
      • 1.2 OpenRefine 的特点
    • 二、OpenRefine 的安装与使用
      • 2.1 安装 OpenRefine
      • 2.2 使用 OpenRefine 进行数据清洗
    • 三、OpenRefine 的案例分析
      • 3.1 电商数据分析案例
      • 3.2 金融数据分析案例
      • 3.3 社交媒体数据分析案例
      • 3.4 医疗数据分析案例
    • 四、OpenRefine 的高级功能
      • 4.1 数据转换
      • 4.2 数据扩展
    • 五、OpenRefine 的工作原理
      • 5.1 数据导入
      • 5.2 数据操作
      • 5.3 数据预览和验证
      • 5.4 数据输出
    • 六、OpenRefine 的挑战与解决方案
      • 6.1 数据量大时的性能问题
      • 6.2 数据格式复杂时的处理问题
    • 七、OpenRefine 的代码示例
  • 结束语:


引言:

在大数据的浩瀚世界中,我们已经领略了 Spark Streaming 在实时数据处理方面的强大威力,如《大数据新视界 --大数据大厂之 Spark Streaming 实时数据处理框架:案例与实践》中所展示的那样,它为我们提供了高效的实时数据处理解决方案。同时,Apache Kylin 的多维分析引擎也在大数据分析中发挥着重要作用,如《大数据新视界 – 大数据大厂之 Kylin 多维分析引擎实战:构建数据立方体》所介绍的,为我们构建数据立方体,助力数据分析。而今天,我们将聚焦于数据清洗工具 OpenRefine,它在大数据处理中扮演着重要的角色,能够帮助我们清理和转换数据,为后续的分析和应用奠定坚实的基础。

在大数据时代,数据的质量至关重要。脏数据、不规范的数据可能会导致分析结果的不准确,甚至误导决策。OpenRefine 作为一款强大的数据清洗工具,能够有效地解决这些问题,让我们的数据更加干净、准确。

在这里插入图片描述

正文:

随着大数据技术的不断发展,数据的规模和复杂性也在不断增加。在这个过程中,数据清洗成为了大数据处理的关键环节之一。OpenRefine 就是一款为了解决数据清洗问题而诞生的工具。

一、OpenRefine 的概述

1.1 什么是 OpenRefine

OpenRefine 是一款开源的数据清洗和转换工具。它可以帮助用户快速地清理和转换各种类型的数据,包括文本数据、数字数据、日期数据等。OpenRefine 提供了丰富的功能,如数据筛选、排序、合并、拆分、正则表达式匹配等,可以满足用户在数据清洗过程中的各种需求。

例如,在一个电商数据分析项目中,我们可能需要清理用户的评论数据,去除其中的噪声和无用信息。OpenRefine 可以帮助我们快速地筛选出有用的评论信息,并进行进一步的分析和处理。

1.2 OpenRefine 的特点

  • 强大的功能:OpenRefine 提供了丰富的功能,可以满足用户在数据清洗和转换过程中的各种需求。它支持多种数据格式的导入和导出,如 CSV、Excel、JSON 等,可以方便地与其他工具进行集成。
    • 数据筛选功能可以根据各种条件快速定位到特定的数据子集。
    • 排序功能能够让数据按照特定的字段进行有序排列,便于查看和分析。
    • 合并功能可以将多个数据源的数据进行整合,提高数据的完整性。
    • 拆分功能则可以将复杂的数据字段拆分成多个独立的部分,方便进一步处理。
    • 正则表达式匹配功能更是强大,可以精确地提取或替换特定格式的数据内容。
  • 易于使用:OpenRefine 的界面简洁直观,操作方便快捷。用户可以通过图形化界面进行数据清洗和转换操作,无需编写复杂的代码。同时,OpenRefine 还提供了丰富的文档和教程,帮助用户快速上手。
    • 对于新手用户来说,只需简单的几步操作就可以完成基本的数据清洗任务。
    • 而对于有经验的用户,OpenRefine 也提供了更多高级的功能和选项,满足复杂的数据处理需求。
  • 高效性:OpenRefine 采用了分布式计算技术,可以快速地处理大规模的数据。它可以在单机上运行,也可以在分布式环境中运行,提高了数据处理的效率。
    • 即使面对海量的数据,OpenRefine 也能在较短的时间内完成数据清洗和转换任务。
    • 在分布式环境下,OpenRefine 可以充分利用多台机器的计算资源,进一步提高处理速度。
  • 开源免费:OpenRefine 是一款开源软件,用户可以免费使用。它的源代码开放,可以让用户根据自己的需求进行定制和扩展。
    • 开源的特性使得 OpenRefine 拥有一个活跃的社区,用户可以在社区中交流经验、分享技巧,共同推动工具的发展。
    • 用户可以根据自己的具体需求对 OpenRefine 进行定制开发,满足个性化的数据处理要求。

二、OpenRefine 的安装与使用

2.1 安装 OpenRefine

  • OpenRefine 可以在多种操作系统上安装,包括 Windows、Mac OS 和 Linux。用户可以从 OpenRefine 的官方网站(https://openrefine.org/download.html)下载安装包。如图:

在这里插入图片描述

  • 选择下载(版本:3.8.2 (2024-07-08))windows免安装,下载后(如图):

在这里插入图片描述

  • 将如上图文件解压后(如图):

在这里插入图片描述

  • 直接打开解压文件,然后点击启动 OpenRefine,后面就可以创建一个新的项目。在创建项目时,用户可以选择导入数据的方式,如从文件导入、从数据库导入等。

在这里插入图片描述

2.2 使用 OpenRefine 进行数据清洗

OpenRefine 提供了丰富的功能,可以帮助用户进行数据清洗。以下是一些常用的功能介绍:

  • 数据筛选:用户可以通过设置筛选条件,筛选出符合条件的数据。例如,用户可以筛选出某一列中特定值的数据,或者筛选出某一列中大于或小于某个值的数据。
    • 可以通过简单的数值比较进行筛选,如筛选出价格大于 100 的商品数据。
    • 也可以通过文本匹配进行筛选,如筛选出包含特定关键词的评论数据。
  • 数据排序:用户可以对数据进行排序,以便更好地查看和分析数据。OpenRefine 支持多种排序方式,如升序排序、降序排序、自定义排序等。
    • 可以按照数字字段进行升序或降序排列,如按照销售额对商品数据进行排序。
    • 也可以根据文本字段进行自定义排序,如按照字母顺序对产品名称进行排序。
  • 数据合并:用户可以将多个数据源中的数据合并到一个数据源中。OpenRefine 支持多种合并方式,如按列合并、按行合并等。
    • 按列合并可以将不同数据源中具有相同字段的数据进行整合,丰富数据内容。
    • 按行合并则可以将多个数据源中的数据逐行拼接在一起,扩大数据规模。
  • 数据拆分:用户可以将一列数据拆分成多列数据。例如,用户可以将一个包含姓名和年龄的字符串拆分成姓名和年龄两列数据。
    • 可以根据特定的分隔符进行拆分,如将“张三,25”拆分成“张三”和“25”两列。
    • 也可以使用正则表达式进行复杂的拆分操作,如从地址字符串中提取出省份、城市和街道信息。
  • 正则表达式匹配:用户可以使用正则表达式对数据进行匹配和替换。例如,用户可以使用正则表达式匹配出某一列中特定格式的数据,并进行替换或删除操作。
    • 可以用正则表达式匹配邮箱地址格式的数据,并进行验证或提取。
    • 也可以用正则表达式替换文本中的特定字符或字符串,实现数据的规范化。

三、OpenRefine 的案例分析

3.1 电商数据分析案例

在一个电商数据分析项目中,我们需要清理用户的评论数据,去除其中的噪声和无用信息。我们可以使用 OpenRefine 进行以下操作:

  • 导入数据:我们可以将用户的评论数据导入到 OpenRefine 中。OpenRefine 支持多种数据格式的导入,如 CSV、Excel、JSON 等。
    • 可以直接从本地文件导入数据,也可以从数据库中导出数据后再导入 OpenRefine。
  • 数据筛选:我们可以设置筛选条件,筛选出有用的评论信息。例如,我们可以筛选出评论长度大于一定值的数据,或者筛选出包含特定关键词的数据。
    • 筛选出评论长度大于 50 个字符的评论,可能更有分析价值。
    • 筛选出包含“好评”“满意”等关键词的评论,了解用户的正面反馈。
  • 数据清理:我们可以使用 OpenRefine 的功能,对评论数据进行清理。例如,我们可以去除评论中的标点符号、空格等无用信息,或者将评论中的大写字母转换为小写字母。
    • 去除标点符号和空格可以使文本更加简洁,便于后续的分析。
    • 将大写字母转换为小写字母可以统一文本格式,避免因大小写不一致而影响分析结果。
  • 数据分析:我们可以对清理后的评论数据进行分析,提取出有用的信息。例如,我们可以分析评论中的情感倾向,或者提取出评论中的产品特征。

以下是一个使用 OpenRefine 进行电商数据分析的示例代码:

import pandas as pd# 导入数据
data = pd.read_csv('comments.csv')# 数据筛选
filtered_data = data[data['comment_length'] > 50]# 数据清理
cleaned_data = filtered_data['comment'].str.replace('[^\w\s]', '').str.lower()# 数据分析
sentiment_analysis = cleaned_data.apply(lambda x: 'positive' if 'good' in x else 'negative')

注释

  • import pandas as pd:导入 Pandas 库。
  • data = pd.read_csv('comments.csv'):从 CSV 文件中导入数据。
  • filtered_data = data[data['comment_length'] > 50]:筛选出评论长度大于 50 的数据。
  • cleaned_data = filtered_data['comment'].str.replace('[^\w\s]', '').str.lower():去除评论中的标点符号和空格,并将大写字母转换为小写字母。
  • sentiment_analysis = cleaned_data.apply(lambda x: 'positive' if 'good' in x else 'negative'):对清理后的评论数据进行情感分析。

3.2 金融数据分析案例

在一个金融数据分析项目中,我们需要清理股票交易数据,去除其中的异常值和错误数据。我们可以使用 OpenRefine 进行以下操作:

  • 导入数据:我们可以将股票交易数据导入到 OpenRefine 中。OpenRefine 支持多种数据格式的导入,如 CSV、Excel、JSON 等。
    • 可以从金融数据提供商处获取数据文件,然后导入 OpenRefine 进行处理。
  • 数据筛选:我们可以设置筛选条件,筛选出正常的交易数据。例如,我们可以筛选出交易价格在合理范围内的数据,或者筛选出交易时间在特定时间段内的数据。
    • 筛选出交易价格在市场合理波动范围内的数据,去除异常高价或低价的数据。
    • 筛选出交易时间在特定交易日内的数据,便于进行特定时间段的分析。
  • 数据清理:我们可以使用 OpenRefine 的功能,对交易数据进行清理。例如,我们可以去除交易数据中的异常值,或者将交易数据中的日期格式转换为统一的格式。
    • 可以使用统计方法识别并去除交易数据中的异常值,提高数据的准确性。
    • 将不同格式的日期数据统一转换为标准格式,方便后续的分析和比较。
  • 数据分析:我们可以对清理后的交易数据进行分析,提取出有用的信息。例如,我们可以分析股票的价格走势,或者计算股票的收益率。

以下是一个使用 OpenRefine 进行金融数据分析的示例代码:

import pandas as pd# 导入数据
data = pd.read_csv('stock_data.csv')# 数据筛选
filtered_data = data[(data['price'] > 0) & (data['price'] < 1000)]# 数据清理
cleaned_data = filtered_data['date'].apply(lambda x: pd.to_datetime(x, format='%Y-%m-%d'))# 数据分析
price_trend = cleaned_data['price'].plot()
return_rate = (cleaned_data['price'].pct_change()).mean()

注释

  • import pandas as pd:导入 Pandas 库。
  • data = pd.read_csv('stock_data.csv'):从 CSV 文件中导入数据。
  • filtered_data = data[(data['price'] > 0) & (data['price'] < 1000)]:筛选出交易价格在 0 到 1000 之间的数据。
  • cleaned_data = filtered_data['date'].apply(lambda x: pd.to_datetime(x, format='%Y-%m-%d')):将交易数据中的日期格式转换为统一的格式。
  • price_trend = cleaned_data['price'].plot():绘制股票的价格走势。
  • return_rate = (cleaned_data['price'].pct_change()).mean():计算股票的收益率。

3.3 社交媒体数据分析案例

在一个社交媒体数据分析项目中,我们需要清理用户的帖子数据,提取出有价值的信息。我们可以使用 OpenRefine 进行以下操作:

  • 导入数据:将社交媒体平台导出的帖子数据导入到 OpenRefine 中。
    • 可以支持从常见的社交媒体数据格式中导入,如 JSON 或 CSV。
  • 数据筛选:筛选出特定话题或特定用户的帖子。
    • 例如,筛选出与某个热门话题相关的帖子,或者筛选出某个影响力较大的用户的帖子。
  • 数据清理:去除帖子中的广告、垃圾信息和重复内容。
    • 使用正则表达式或特定的文本处理方法去除广告和垃圾信息。
    • 通过比较文本内容去除重复的帖子。
  • 数据分析:分析帖子的情感倾向、话题热度和用户互动情况。
    • 利用自然语言处理技术分析帖子的情感倾向,判断用户对特定话题的态度。
    • 统计不同话题的帖子数量,了解话题热度。
    • 分析用户的点赞、评论和转发数量,了解用户互动情况。

以下是一个简单的示例代码,用于展示如何使用 Python 的一些库来进行类似的分析:

import pandas as pd
from textblob import TextBlob# 假设已经导入了社交媒体帖子数据到 data 变量中
data = pd.read_csv('social_media_data.csv')# 数据筛选
filtered_data = data[data['topic'] == '特定话题']# 数据清理
cleaned_data = filtered_data['text'].apply(lambda x: x.replace('广告内容', ''))# 数据分析
sentiment_scores = cleaned_data.apply(lambda x: TextBlob(x).sentiment.polarity)
topic_heat = filtered_data['topic'].value_counts()
user_interaction = filtered_data[['likes', 'comments', 'shares']].mean()

注释

  • import pandas as pd:导入 Pandas 库用于数据处理。
  • from textblob import TextBlob:导入 TextBlob 库用于情感分析。
  • data = pd.read_csv('social_media_data.csv'):从 CSV 文件中导入社交媒体帖子数据。
  • filtered_data = data[data['topic'] == '特定话题']:筛选出特定话题的帖子。
  • cleaned_data = filtered_data['text'].apply(lambda x: x.replace('广告内容', '')):去除帖子中的广告内容。
  • sentiment_scores = cleaned_data.apply(lambda x: TextBlob(x).sentiment.polarity):计算帖子的情感倾向得分。
  • topic_heat = filtered_data['topic'].value_counts():统计特定话题的热度。
  • user_interaction = filtered_data[['likes', 'comments', 'shares']].mean():计算用户互动情况的平均值。

3.4 医疗数据分析案例

在医疗数据分析项目中,我们常常需要处理大量的患者病历数据。OpenRefine 可以帮助我们清理和转换这些数据,以便进行更深入的分析。

  • 导入数据:可以将电子病历系统导出的数据导入 OpenRefine,支持的格式包括 CSV、Excel 等。
  • 数据筛选:筛选出特定疾病的患者数据,或者根据治疗阶段进行筛选。
    • 例如,筛选出患有糖尿病的患者记录,或者筛选出处于康复期的患者数据。
  • 数据清理:去除数据中的错误信息和不规范的内容。
    • 纠正病历中的错别字,统一医学术语的表达方式。
  • 数据分析:分析患者的治疗效果、疾病发展趋势等。

以下是一个简单的示例代码,假设我们有一个包含患者年龄和疾病类型的数据集:

import pandas as pddata = pd.read_csv('medical_data.csv')# 筛选特定疾病患者
filtered_data = data[data['disease'] == 'diabetes']# 清理年龄列中的异常值
cleaned_data = filtered_data[filtered_data['age'] > 0]

注释

  • import pandas as pd:导入 Pandas 库。
  • data = pd.read_csv('medical_data.csv'):从 CSV 文件中导入医疗数据。
  • filtered_data = data[data['disease'] == 'diabetes']:筛选出患有糖尿病的患者数据。
  • cleaned_data = filtered_data[filtered_data['age'] > 0]:去除年龄列中的异常值(年龄小于等于 0 的数据)。

四、OpenRefine 的高级功能

4.1 数据转换

OpenRefine 提供了丰富的数据转换功能,可以将数据从一种格式转换为另一种格式。例如,用户可以将日期数据从一种格式转换为另一种格式,或者将数字数据从一种单位转换为另一种单位。

以下是一个使用 OpenRefine 进行数据转换的示例代码:

import pandas as pd# 导入数据
data = pd.read_csv('data.csv')# 日期格式转换
date_column = data['date']
try:converted_dates = pd.to_datetime(date_column, format='%Y-%m-%d', errors='coerce').dt.strftime('%Y/%m/%d')data['date'] = converted_dates
except ValueError as e:print(f"日期转换错误:{e}。处理方式:保留原始日期值。")# 数字单位转换
numeric_column = data['price']
try:converted_numbers = numeric_column * 2data['price'] = converted_numbers
except TypeError as e:print(f"数字转换错误:{e}。处理方式:保留原始数字值。")

注释

  • import pandas as pd:导入 Pandas 库。

  • data = pd.read_csv(‘data.csv’)`:从 CSV 文件中导入数据。

  • date_column = data['date']:提取日期列。

  • converted_dates = pd.to_datetime(date_column, format='%Y-%m-%d', errors='coerce').dt.strftime('%Y/%m/%d'):将日期格式转换为特定格式。

  • data['date'] = converted_dates:更新日期列。

  • numeric_column = data['price']:提取数字列。

  • converted_numbers = numeric_column * 2:对数字列进行特定转换(这里是乘以 2)。

  • data['price'] = converted_numbers:更新数字列。

4.2 数据扩展

OpenRefine 还提供了数据扩展功能,可以通过添加外部数据源来扩展数据。例如,用户可以添加一个包含地理位置信息的数据源,然后将其与现有的数据进行合并,以获取更多的信息。

以下是一个使用 OpenRefine 进行数据扩展的示例代码:

import pandas as pd# 导入数据
data = pd.read_csv('data.csv')try:# 导入地理位置数据geo_data = pd.read_csv('geo_data.csv')extended_data = pd.merge(data, geo_data, on='id')
except FileNotFoundError as e:print(f"文件未找到错误:{e}。处理方式:不进行数据扩展。")

注释

  • import pandas as pd:导入 Pandas 库。
  • data = pd.read_csv('data.csv'):从 CSV 文件中导入数据。
  • geo_data = pd.read_csv('geo_data.csv'):从另一个 CSV 文件中导入地理位置信息数据。
  • extended_data = pd.merge(data, geo_data, on='id'):将两个数据源进行合并,以获取更多的信息。

五、OpenRefine 的工作原理

5.1 数据导入

OpenRefine 支持多种数据格式的导入,包括 CSV、Excel、JSON 等。用户可以从本地文件系统、数据库或者网络数据源中导入数据。在导入数据时,OpenRefine 会对数据进行解析和预处理,将其转换为内部的数据结构,以便后续的操作。

5.2 数据操作

一旦数据被导入,用户就可以使用 OpenRefine 提供的各种功能对数据进行操作。这些功能包括数据筛选、排序、合并、拆分、正则表达式匹配、数据转换等。用户可以通过图形化界面或者命令行界面来执行这些操作,无需编写复杂的代码。

5.3 数据预览和验证

在进行数据操作的过程中,OpenRefine 会实时显示数据的预览,以便用户查看操作的效果。用户可以随时对数据进行验证和检查,确保数据的准确性和完整性。如果发现问题,用户可以及时调整操作,或者回滚到之前的状态。

5.4 数据输出

当数据操作完成后,用户可以将数据输出到各种格式的文件中,如 CSV、Excel、JSON 等。用户也可以将数据导出到数据库或者其他数据源中,以便进行进一步的分析和处理。

总之,OpenRefine 通过提供丰富的功能和灵活的操作方式,帮助用户快速、高效地清理和转换数据,提高数据的质量和可用性。

六、OpenRefine 的挑战与解决方案

6.1 数据量大时的性能问题

当处理大规模数据时,OpenRefine 可能会出现性能问题。解决方法可以是使用分布式计算技术,将数据分割成多个小块,分别在不同的节点上进行处理,然后将结果合并起来。

  • 可以利用 Hadoop 或 Spark 等分布式计算框架,与 OpenRefine 结合使用,提高处理大规模数据的效率。
  • 也可以通过调整 OpenRefine 的内存设置和并行处理参数,优化其性能。

6.2 数据格式复杂时的处理问题

当数据格式非常复杂时,OpenRefine 可能无法直接处理。解决方法可以是使用其他工具进行预处理,将数据转换为 OpenRefine 能够处理的格式,然后再使用 OpenRefine 进行清洗和转换。

  • 对于一些特殊格式的数据,如嵌套的 JSON 结构或自定义的二进制格式,可以先使用专门的解析工具进行初步处理,提取出关键信息后再导入 OpenRefine。
  • 也可以编写自定义的脚本或插件,扩展 OpenRefine 的功能,以适应复杂的数据格式。

七、OpenRefine 的代码示例

以下是一个使用 OpenRefine 进行数据清洗和转换的完整示例代码:

import pandas as pd# 导入数据
data = pd.read_csv('data.csv')# 数据筛选
filtered_data = data[data['column1'] > 100]# 数据清理
cleaned_data = filtered_data['column2'].str.replace('[^\w\s]', '').str.lower()# 去除重复行
unique_data = cleaned_data.drop_duplicates()# 日期转换
date_column = unique_data['column3']
try:converted_dates = pd.to_datetime(date_column, format='%Y-%m-%d', errors='coerce').dt.strftime('%Y/%m/%d')unique_data['column3'] = converted_dates
except ValueError as e:print(f"日期转换错误:{e}。处理方式:保留原始日期值。")# 数字转换
numeric_column = unique_data['column4']
try:converted_numbers = numeric_column * 2unique_data['column4'] = converted_numbers
except TypeError as e:print(f"数字转换错误:{e}。处理方式:保留原始数字值。")# 字符串分割与合并
string_column = unique_data['column5']
try:split_strings = string_column.str.split('_')new_column = split_strings.str[0] + '-' + split_strings.str[1]unique_data['new_column'] = new_column
except AttributeError as e:print(f"字符串处理错误:{e}。处理方式:保留原始字符串值。")# 数据扩展
try:geo_data = pd.read_csv('geo_data.csv')extended_data = pd.merge(unique_data, geo_data, on='id')
except FileNotFoundError as e:print(f"文件未找到错误:{e}。处理方式:不进行数据扩展。")# 输出结果
extended_data.to_csv('cleaned_data.csv', index=False)

注释

  • import pandas as pd:导入 Pandas 库。
  • data = pd.read_csv('data.csv'):从 CSV 文件中导入数据。
  • filtered_data = data[data['column1'] > 100]:筛选出某一列中大于 100 的数据。
  • cleaned_data = filtered_data['column2'].str.replace('[^\w\s]', '').str.lower():去除某一列中的标点符号和空格,并将大写字母转换为小写字母。
  • unique_data = cleaned_data.drop_duplicates():去除重复行。
  • date_column = unique_data['column3']:提取日期列。
  • converted_dates = pd.to_datetime(date_column, format='%Y-%m-%d', errors='coerce').dt.strftime('%Y/%m/%d'):将日期格式转换为特定格式。
  • unique_data['column3'] = converted_dates:更新日期列。
  • numeric_column = unique_data['column4']:提取数字列。
  • converted_numbers = numeric_column * 2:对数字列进行特定转换(这里是乘以 2)。
  • unique_data['column4'] = converted_numbers:更新数字列。
  • string_column = unique_data['column5']:提取字符串列。
  • split_strings = string_column.str.split('_'):按特定字符分割字符串列。
  • new_column = split_strings.str[0] + '-' + split_strings.str[1]:合并分割后的字符串。
  • unique_data['new_column'] = new_column:添加新的合并后的列。
  • geo_data = pd.read_csv('geo_data.csv'):从另一个 CSV 文件中导入地理位置信息数据。
  • extended_data = pd.merge(unique_data, geo_data, on='id'):将两个数据源进行合并,以获取更多的信息。
  • extended_data.to_csv('cleaned_data.csv', index=False):将处理后的结果输出到一个 CSV 文件中。

结束语:

OpenRefine 为大数据处理中的数据清洗提供了强大而灵活的解决方案。通过本文的介绍,相信你对 OpenRefine 的功能和应用有了更深入的了解。在大数据的浪潮中,让我们充分利用 OpenRefine 这样的工具,不断提升数据质量,挖掘数据的价值,为决策提供更准确的依据。无论是在电商、金融、社交媒体还是医疗等领域,OpenRefine 都能发挥重要作用,助力我们在大数据的海洋中乘风破浪,开启数据驱动的新时代。

希望通过本文的介绍,能让你对 OpenRefine 有更深入的了解和认识,在大数据处理中更好地利用这个强大的工具。让我们一起在数据的海洋中畅游,挖掘出更多有价值的信息。

大家在项目中,使用过 OpenRefine 吗?遇到了哪些问题,是如何解决的?对于 OpenRefine 的数据筛选和清理功能,你们有哪些经验和建议?在选择数据清洗工具时,你们会考虑哪些因素?OpenRefine 在其中扮演着怎样的角色?如何利用 OpenRefine 的数据转换和扩展功能,提高数据分析的效率?对于 OpenRefine 的未来发展,你们有哪些期待和展望?在实际操作中,你们是如何处理大规模数据和复杂数据格式的问题的?分享一下你们在使用 OpenRefine 进行数据清洗和转换时的成功案例和经验教训。欢迎大家在评论区或CSDN社区积极参与讨论,分享自己的经验和见解,让我们一起探讨,共同进步!


———— 精 选 文 章 ————
  1. 大数据新视界 --大数据大厂之 Spark Streaming 实时数据处理框架:案例与实践(最新)
  2. 大数据新视界 --大数据大厂之 Kylin 多维分析引擎实战:构建数据立方体(最新)
  3. 大数据新视界 --大数据大厂之HBase 在大数据存储中的应用与表结构设计(最新)
  4. 大数据新视界 --大数据大厂之大数据实战指南:Apache Flume 数据采集的配置与优化秘籍(最新)
  5. 大数据新视界 --大数据大厂之大数据存储技术大比拼:选择最适合你的方案(最新)
  6. 大数据新视界 --大数据大厂之 Reactjs 在大数据应用开发中的优势与实践(最新)
  7. 大数据新视界 --大数据大厂之 Vue.js 与大数据可视化:打造惊艳的数据界面(最新)
  8. 大数据新视界 --大数据大厂之 Node.js 与大数据交互:实现高效数据处理(最新)
  9. 大数据新视界 --大数据大厂之JavaScript在大数据前端展示中的精彩应用(最新)
  10. 大数据新视界 --大数据大厂之AI 与大数据的融合:开创智能未来的新篇章(最新)
  11. 大数据新视界 --大数据大厂之算法在大数据中的核心作用:提升效率与智能决策(最新)
  12. 大数据新视界 --大数据大厂之DevOps与大数据:加速数据驱动的业务发展(最新)
  13. 大数据新视界 --大数据大厂之SaaS模式下的大数据应用:创新与变革(最新)
  14. 大数据新视界 --大数据大厂之Kubernetes与大数据:容器化部署的最佳实践(最新)
  15. 大数据新视界 --大数据大厂之探索ES:大数据时代的高效搜索引擎实战攻略(最新)
  16. 大数据新视界 --大数据大厂之Redis在缓存与分布式系统中的神奇应用(最新)
  17. 大数据新视界 --大数据大厂之数据驱动决策:如何利用大数据提升企业竞争力(最新)
  18. 大数据新视界 --大数据大厂之MongoDB与大数据:灵活文档数据库的应用场景(最新)
  19. 大数据新视界 --大数据大厂之数据科学项目实战:从问题定义到结果呈现的完整流程(最新)
  20. 大数据新视界 --大数据大厂之 Cassandra 分布式数据库:高可用数据存储的新选择(最新)
  21. 大数据新视界 --大数据大厂之数据安全策略:保护大数据资产的最佳实践(最新)
  22. 大数据新视界 --大数据大厂之Kafka消息队列实战:实现高吞吐量数据传输(最新)
  23. 大数据新视界 --大数据大厂之数据挖掘入门:用 R 语言开启数据宝藏的探索之旅(最新)
  24. 大数据新视界 --大数据大厂之HBase深度探寻:大规模数据存储与查询的卓越方案(最新)
  25. IBM 中国研发部裁员风暴,IT 行业何去何从?(最新)
  26. 大数据新视界 --大数据大厂之数据治理之道:构建高效大数据治理体系的关键步骤(最新)
  27. 大数据新视界 --大数据大厂之Flink强势崛起:大数据新视界的璀璨明珠(最新)
  28. 大数据新视界 --大数据大厂之数据可视化之美:用 Python 打造炫酷大数据可视化报表(最新)
  29. 大数据新视界 --大数据大厂之 Spark 性能优化秘籍:从配置到代码实践(最新)
  30. 大数据新视界 --大数据大厂之揭秘大数据时代 Excel 魔法:大厂数据分析师进阶秘籍(最新)
  31. 大数据新视界 --大数据大厂之Hive与大数据融合:构建强大数据仓库实战指南(最新)
  32. 大数据新视界–大数据大厂之Java 与大数据携手:打造高效实时日志分析系统的奥秘(最新)
  33. 大数据新视界–面向数据分析师的大数据大厂之MySQL基础秘籍:轻松创建数据库与表,踏入大数据殿堂(最新)
  34. 全栈性能优化秘籍–Linux 系统性能调优全攻略:多维度优化技巧大揭秘(最新)
  35. 大数据新视界–大数据大厂之MySQL数据库课程设计:揭秘 MySQL 集群架构负载均衡核心算法:从理论到 Java 代码实战,让你的数据库性能飙升!(最新)
  36. 大数据新视界–大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案(最新)
  37. 解锁编程高效密码:四大工具助你一飞冲天!(最新)
  38. 大数据新视界–大数据大厂之MySQL数据库课程设计:MySQL数据库高可用性架构探索(2-1)(最新)
  39. 大数据新视界–大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡方法选择全攻略(2-2)(最新)
  40. 大数据新视界–大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)(最新)
  41. 大数据新视界–大数据大厂之MySQL 数据库课程设计:MySQL 数据库 SQL 语句调优的进阶策略与实际案例(2-2)(最新)
  42. 大数据新视界–大数据大厂之MySQL 数据库课程设计:数据安全深度剖析与未来展望(最新)
  43. 大数据新视界–大数据大厂之MySQL 数据库课程设计:开启数据宇宙的传奇之旅(最新)
  44. 大数据新视界–大数据大厂之大数据时代的璀璨导航星:Eureka 原理与实践深度探秘(最新)
  45. Java性能优化传奇之旅–Java万亿级性能优化之Java 性能优化逆袭:常见错误不再是阻碍(最新)
  46. Java性能优化传奇之旅–Java万亿级性能优化之Java 性能优化传奇:热门技术点亮高效之路(最新)
  47. Java性能优化传奇之旅–Java万亿级性能优化之电商平台高峰时段性能优化:多维度策略打造卓越体验(最新)
  48. Java性能优化传奇之旅–Java万亿级性能优化之电商平台高峰时段性能大作战:策略与趋势洞察(最新)
  49. JVM万亿性能密码–JVM性能优化之JVM 内存魔法:开启万亿级应用性能新纪元(最新)
  50. 十万流量耀前路,成长感悟谱新章(最新)
  51. AI 模型:全能与专精之辩 —— 一场科技界的 “超级大比拼”(最新)
  52. 国产游戏技术:挑战与机遇(最新)
  53. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(10)(最新)
  54. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(9)(最新)
  55. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(8)(最新)
  56. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(7)(最新)
  57. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(6)(最新)
  58. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(5)(最新)
  59. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(4)(最新)
  60. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(3)(最新)
  61. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(2)(最新)
  62. Java面试题–JVM大厂篇之JVM大厂面试题及答案解析(1)(最新)
  63. Java 面试题 ——JVM 大厂篇之 Java 工程师必备:顶尖工具助你全面监控和分析 CMS GC 性能(2)(最新)
  64. Java面试题–JVM大厂篇之Java工程师必备:顶尖工具助你全面监控和分析CMS GC性能(1)(最新)
  65. Java面试题–JVM大厂篇之未来已来:为什么ZGC是大规模Java应用的终极武器?(最新)
  66. AI 音乐风暴:创造与颠覆的交响(最新)
  67. 编程风暴:勇破挫折,铸就传奇(最新)
  68. Java面试题–JVM大厂篇之低停顿、高性能:深入解析ZGC的优势(最新)
  69. Java面试题–JVM大厂篇之解密ZGC:让你的Java应用高效飞驰(最新)
  70. Java面试题–JVM大厂篇之掌控Java未来:深入剖析ZGC的低停顿垃圾回收机制(最新)
  71. GPT-5 惊涛来袭:铸就智能新传奇(最新)
  72. AI 时代风暴:程序员的核心竞争力大揭秘(最新)
  73. Java面试题–JVM大厂篇之Java新神器ZGC:颠覆你的垃圾回收认知!(最新)
  74. Java面试题–JVM大厂篇之揭秘:如何通过优化 CMS GC 提升各行业服务器响应速度(最新)
  75. “低代码” 风暴:重塑软件开发新未来(最新)
  76. 程序员如何平衡日常编码工作与提升式学习?–编程之路:平衡与成长的艺术(最新)
  77. 编程学习笔记秘籍:开启高效学习之旅(最新)
  78. Java面试题–JVM大厂篇之高并发Java应用的秘密武器:深入剖析GC优化实战案例(最新)
  79. Java面试题–JVM大厂篇之实战解析:如何通过CMS GC优化大规模Java应用的响应时间(最新)
  80. Java面试题–JVM大厂篇(1-10)
  81. Java面试题–JVM大厂篇之Java虚拟机(JVM)面试题:涨知识,拿大厂Offer(11-20)
  82. Java面试题–JVM大厂篇之JVM面试指南:掌握这10个问题,大厂Offer轻松拿
  83. Java面试题–JVM大厂篇之Java程序员必学:JVM架构完全解读
  84. Java面试题–JVM大厂篇之以JVM新特性看Java的进化之路:从Loom到Amber的技术篇章
  85. Java面试题–JVM大厂篇之深入探索JVM:大厂面试官心中的那些秘密题库
  86. Java面试题–JVM大厂篇之高级Java开发者的自我修养:深入剖析JVM垃圾回收机制及面试要点
  87. Java面试题–JVM大厂篇之从新手到专家:深入探索JVM垃圾回收–开端篇
  88. Java面试题–JVM大厂篇之Java性能优化:垃圾回收算法的神秘面纱揭开!
  89. Java面试题–JVM大厂篇之揭秘Java世界的清洁工——JVM垃圾回收机制
  90. Java面试题–JVM大厂篇之掌握JVM性能优化:选择合适的垃圾回收器
  91. Java面试题–JVM大厂篇之深入了解Java虚拟机(JVM):工作机制与优化策略
  92. Java面试题–JVM大厂篇之深入解析JVM运行时数据区:Java开发者必读
  93. Java面试题–JVM大厂篇之从零开始掌握JVM:解锁Java程序的强大潜力
  94. Java面试题–JVM大厂篇之深入了解G1 GC:大型Java应用的性能优化利器
  95. Java面试题–JVM大厂篇之深入了解G1 GC:高并发、响应时间敏感应用的最佳选择
  96. Java面试题–JVM大厂篇之G1 GC的分区管理方式如何减少应用线程的影响
  97. Java面试题–JVM大厂篇之深入解析G1 GC——革新Java垃圾回收机制
  98. Java面试题–JVM大厂篇之深入探讨Serial GC的应用场景
  99. Java面试题–JVM大厂篇之Serial GC在JVM中有哪些优点和局限性
  100. Java面试题–JVM大厂篇之深入解析JVM中的Serial GC:工作原理与代际区别
  101. Java面试题–JVM大厂篇之通过参数配置来优化Serial GC的性能
  102. Java面试题–JVM大厂篇之深入分析Parallel GC:从原理到优化
  103. Java面试题–JVM大厂篇之破解Java性能瓶颈!深入理解Parallel GC并优化你的应用
  104. Java面试题–JVM大厂篇之全面掌握Parallel GC参数配置:实战指南
  105. Java面试题–JVM大厂篇之Parallel GC与其他垃圾回收器的对比与选择
  106. Java面试题–JVM大厂篇之Java中Parallel GC的调优技巧与最佳实践
  107. Java面试题–JVM大厂篇之JVM监控与GC日志分析:优化Parallel GC性能的重要工具
  108. Java面试题–JVM大厂篇之针对频繁的Minor GC问题,有哪些优化对象创建与使用的技巧可以分享?
  109. Java面试题–JVM大厂篇之JVM 内存管理深度探秘:原理与实战
  110. Java面试题–JVM大厂篇之破解 JVM 性能瓶颈:实战优化策略大全
  111. Java面试题–JVM大厂篇之JVM 垃圾回收器大比拼:谁是最佳选择
  112. Java面试题–JVM大厂篇之从原理到实践:JVM 字节码优化秘籍
  113. Java面试题–JVM大厂篇之揭开CMS GC的神秘面纱:从原理到应用,一文带你全面掌握
  114. Java面试题–JVM大厂篇之JVM 调优实战:让你的应用飞起来
  115. Java面试题–JVM大厂篇之CMS GC调优宝典:从默认配置到高级技巧,Java性能提升的终极指南
  116. Java面试题–JVM大厂篇之CMS GC的前世今生:为什么它曾是Java的王者,又为何将被G1取代
  117. Java就业-学习路线–突破性能瓶颈: Java 22 的性能提升之旅
  118. Java就业-学习路线–透视Java发展:从 Java 19 至 Java 22 的飞跃
  119. Java就业-学习路线–Java技术:2024年开发者必须了解的10个要点
  120. Java就业-学习路线–Java技术栈前瞻:未来技术趋势与创新
  121. Java就业-学习路线–Java技术栈模块化的七大优势,你了解多少?
  122. Spring框架-Java学习路线课程第一课:Spring核心
  123. Spring框架-Java学习路线课程:Spring的扩展配置
  124. Springboot框架-Java学习路线课程:Springboot框架的搭建之maven的配置
  125. Java进阶-Java学习路线课程第一课:Java集合框架-ArrayList和LinkedList的使用
  126. Java进阶-Java学习路线课程第二课:Java集合框架-HashSet的使用及去重原理
  127. JavaWEB-Java学习路线课程:使用MyEclipse工具新建第一个JavaWeb项目(一)
  128. JavaWEB-Java学习路线课程:使用MyEclipse工具新建项目时配置Tomcat服务器的方式(二)
  129. Java学习:在给学生演示用Myeclipse10.7.1工具生成War时,意外报错:SECURITY: INTEGRITY CHECK ERROR
  130. 使用Jquery发送Ajax请求的几种异步刷新方式
  131. Idea Springboot启动时内嵌tomcat报错- An incompatible version [1.1.33] of the APR based Apache Tomcat Native
  132. Java入门-Java学习路线课程第一课:初识JAVA
  133. Java入门-Java学习路线课程第二课:变量与数据类型
  134. Java入门-Java学习路线课程第三课:选择结构
  135. Java入门-Java学习路线课程第四课:循环结构
  136. Java入门-Java学习路线课程第五课:一维数组
  137. Java入门-Java学习路线课程第六课:二维数组
  138. Java入门-Java学习路线课程第七课:类和对象
  139. Java入门-Java学习路线课程第八课:方法和方法重载
  140. Java入门-Java学习路线扩展课程:equals的使用
  141. Java入门-Java学习路线课程面试篇:取商 / 和取余(模) % 符号的使用

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/435002.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

尚硅谷vue3+TypeScript笔记大全

源码及视频&#xff1a;通过百度网盘分享的文件&#xff1a;尚硅谷vue3 链接&#xff1a;https://pan.baidu.com/s/19zVM5Xsr1UP7tZ4D0mhVqA?pwdgmta 提取码&#xff1a;gmta 1. Vue3简介 2020年9月18日&#xff0c;Vue.js发布版3.0版本&#xff0c;代号&#xff1a;One Piec…

Qualcomm AI Hub模型优化1: Whisper-Base-En导出及问题解决

1 从Qualcomm AI Hub Module中选择Whisper-Base-En模块部署 1.1 进入module虚拟环境 python3 -m venv qai_hub_models_env && source qai_hub_models_env/bin/activate1.2 使用pip安装高通音频转录包 pip install "qai_hub_models[whisper_base_en]" 1.3…

人工智能对话系统/AI助理/PC/公众号/h5/小程序

>>>系统简述&#xff1a; GPTCMS基于TP6UniappVUE3开发&#xff0c;已集成文心一言、灵犀星火、ChatGLM&#xff08;清华旗下&#xff09;、讯飞星火&#xff08;即将&#xff09;、api2d、意间AI、ChatGPT、GPT3.5、GPT4、Stable Diffusion、MidJourney-V4、MidJour…

基于Python大数据可视化的民族服饰数据分析系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目…

第十届蓝桥杯嵌入式省赛程序设计题解析(基于HAL库)

一.题目分析 &#xff08;1&#xff09;.题目 &#xff08;2&#xff09;.题目分析 1.参考配置界面 注意上限和下限的调整&#xff0c;上限值必须大于下限值&#xff0c;低于下限LD2会闪烁&#xff0c;低于上限LD1会闪烁 2.按键功能分析 B1&#xff1a;显示界面和设置界面相互切…

Java IO 和 NIO

在 Java 编程中&#xff0c;输入输出&#xff08;IO&#xff09;是不可或缺的部分&#xff0c;随着技术的发展&#xff0c;Java 的 IO 系统也经历了显著的变化。本文将深入探讨 Java IO 和 NIO 的历史、优缺点以及适用场景。 1. Java IO 的历史 Java IO 包&#xff08;java.i…

Solidity智能合约中的异常处理(error、require 和 assert)

Solidity 中的三种抛出异常方法&#xff1a;error、require 和 assert 在 Solidity 开发中&#xff0c;异常处理是确保智能合约安全性和正确性的关键步骤。Solidity 提供了三种主要方法来抛出异常&#xff1a;error、require 和 assert。本文将详细介绍这三种方法的用途、实现方…

nginx+keepalived健康检查案例详解(解决nginx出现故障却不能快速切换到备份服务器的问题)

文章目录 简介配置过程前置环境请看创建健康检查脚本结果测试 简介 在我们通过nginxkeepalived实现高可用后&#xff0c;会发现nginx出现故障的时候keepalived并不会将虚拟ip切换到备份服务器上其原理就是nginx和keepalived是两个独立的服务&#xff0c;Nginx的故障状态不会触…

使用Docker-Compose部署SpringBoot项目的案例

Docker-Compose是Docker官方的一个开源项目&#xff0c;主要用于实现对Docker容器集群的快速编排和管理。该项目由Python编写&#xff0c;通过调用Docker服务提供的API来管理容器。只要所操作的平台支持Docker API&#xff0c;就可以利用Docker-Compose进行编排管理。Docker-Co…

【微服务即时通讯系统】——brpc远程过程调用、百度开源的RPC框架、brpc的介绍、brpc的安装、brpc使用和功能测试

文章目录 brpc1. brpc的介绍1.1 rpc的介绍1.2 rpc的原理1.3 grpc和brpc 2. brpc的安装3. brpc使用3.1 brpc接口介绍 4. brpc使用测试4.1 brpc同步和异步调用 brpc 1. brpc的介绍 1.1 rpc的介绍 RPC&#xff08;Remote Procedure Call&#xff09;远程过程调用&#xff0c;是一…

X86下一文带你构建Apollo9.0运行环境(基于Ubuntu20.04避坑版)

X86下一文带你构建Apollo9.0运行环境基于Ubuntu20.04避坑版 前言准备安装基础软件1.安装Docker19.03安装Nvidia驱动安装配置Nvidia container toolkit 下载Apollo源码&#xff08;笔者下载的是releases下9.0.0版本&#xff0c;大家可以参考&#xff09;编译Apollo9.0下载资源包…

如何使用GitHub Desktop管理GitLab库

不管是新手还是老手&#xff0c;Github Desktop都是在苹果系统和Windows系统上管理与创建项目的不错的方式&#xff0c;GitHub Desktop都能够让在GitHub上的工作流更为简单快捷。 注意&#xff0c;以下步骤只支持原版的GitHub Desktop 第一步 从这下载GitHub Desktop打开你的G…

【hot100-java】【柱状图中最大的矩形】

R9-栈篇 面积最大矩形的高度一定是 heights 中的元素 简单解释&#xff0c;就是说&#xff0c;最大高度必然是heights中的一个元素&#xff0c;我们假设是h&#xff0c;然后我们基于h&#xff0c;左右拓展&#xff0c;尽量拓展到h越来越高&#xff08;符合单调栈&#xff09;&a…

手机改IP地址怎么弄?全面解析与操作指南

在当今数字化时代&#xff0c;IP地址作为设备在网络中的唯一标识&#xff0c;其重要性不言而喻。有时候&#xff0c;出于隐私保护、网络访问需求或其他特定原因&#xff0c;我们可能需要更改手机的IP地址。然而&#xff0c;对于大多数普通用户来说&#xff0c;如何操作可能还是…

Redis 篇-深入了解 Redis 中的 RESP 通信协议与内存回收(过期 key 处理、内存淘汰策略)

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 Redis 通信协议 - RESP 协议 2.0 Redis 内存回收 2.1 Redis 内存回收 - 过期 key 处理 2.1.1 Redis 是如何知道一个 Key 是否过期呢&#xff1f; 2.1.2 是不是 TT…

Linux基础(三):安装CentOS7(系统安装+桥接联网+换源)

1.分区设置 由于使用 GPT 的关系&#xff0c; 因此根本无须考虑主/延伸/逻辑分区的差异。CentOS 默认使用 LVM 的方式来管理你的文件系统。使用GPT进行分区&#xff1a; 开机管理程序&#xff08; boot loader&#xff09; 使用CentOS 7.x默认的grub2软件。 2.各种分区格式 …

DataLight(V1.4.5) 版本更新,新增 Ranger、Solr

DataLight&#xff08;V1.4.5&#xff09; 版本更新&#xff0c;新增 Ranger、Solr DataLight 迎来了重大的版本更新&#xff0c;现已发布 V1.4.5 版本。本次更新对平台进行了较多的功能拓展和优化&#xff0c;新增了对 Ranger 和 Solr 服务组件的支持&#xff0c;同时对多项已…

Oracle 配置恢复目录catalog

一.介绍 Oracle中使用RMAN备份的数据我们分为两类 RMAN知识库数据库的数据块 Oracle默认把 RMAN知识库 放在目标数据库的控制文件中&#xff0c;在以后进行恢复的时候 我们要先读知识库的信息然后才能恢复。 但这样就产生了一个问题&#xff0c;知识库放在了控制文件上&#xf…

【C++】set与map

目录 一、预备知识&#xff1a; 1、关联式容器&#xff1a; 2、键值对&#xff1a; 3、树形结构的关联式容器&#xff1a; 二、set&#xff1a; 1、set的介绍&#xff1a; 2、使用&#xff1a; 1、set的构造&#xff1a; 2、set的各种功能&#xff1a; 3、multiset 三…

AOP-代理实现

三种代理实现 1 JDK动态代理实现-基于接口代理 2 CGLIB动态代理实现-基于类代理 3 AspectJ 适配实现 为什么Proxy.newProxyInstance 会生成新的字节码&#xff1f; 创建代理类&#xff1a; Proxy.newProxyInstance 首先会检查缓存中是否有已存在的代理类字节码。 如果没有&…