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

数据工程流程

** 数据工程流程图**

API调用 / 爬取数据
处理缺失值 / 异常值
生成统计报告 / 可视化
标注任务与审核
特征工程 / 数据增强
数据采集
数据清洗
数据分析
人工标注
数据构造
输出数据集

各步骤详解与具体实现

1. 数据采集

数据采集是获取数据的第一步。以下是常见的采集方式及其实现示例:

具体实现:
  1. 通过 API 采集数据

    • 示例:从公开 API 获取天气数据。
    import requestsapi_url = "http://api.weatherapi.com/v1/current.json"
    params = {"key": "your_api_key","q": "London"
    }
    response = requests.get(api_url, params=params)
    if response.status_code == 200:data = response.json()print(data)
    else:print("Failed to fetch data")
    
  2. 爬取网页数据

    • 示例:使用 BeautifulSoup 抓取新闻标题。
    import requests
    from bs4 import BeautifulSoupurl = "https://news.ycombinator.com/"
    response = requests.get(url)
    soup = BeautifulSoup(response.text, 'html.parser')titles = [title.get_text() for title in soup.find_all('a', class_='storylink')]
    print(titles)
    
注意事项:
  • 确保数据来源合法,遵守隐私和数据采集政策。
  • 针对大规模数据采集,考虑使用并发工具如 aiohttpscrapy

2. 数据清洗

数据清洗是数据工程中的关键环节,用于提升数据质量,便于后续分析。

具体实现:
  1. 去重与填充缺失值

    import pandas as pddata = pd.DataFrame({'Name': ['Alice', 'Bob', 'Alice', None],'Age': [25, 30, 25, 29],'Score': [90, None, 90, 85]
    })# 去除重复值
    data = data.drop_duplicates()# 填充缺失值
    data['Score'] = data['Score'].fillna(data['Score'].mean())
    data['Name'] = data['Name'].fillna("Unknown")print(data)
    
  2. 格式转换与异常值处理

    # 转换日期格式
    data['Date'] = pd.to_datetime(data['Date'], errors='coerce')# 检测异常值
    z_scores = (data['Score'] - data['Score'].mean()) / data['Score'].std()
    data = data[z_scores.abs() < 3]  # 去除 Z-score 超过 3 的异常值
    
注意事项:
  • 缺失值的填充策略应根据业务需求选择(如均值、插值、特定值填充)。
  • 异常值检测可以使用统计方法(如箱型图或 Z-score)。

3. 数据分析

数据分析包括探索性数据分析(EDA)和统计建模,目的是挖掘数据特征,为决策提供依据。

具体实现:
  1. 生成数据统计报告

    import pandas as pddata = pd.read_csv('data.csv')
    print(data.describe())  # 生成统计摘要
    
  2. 可视化分析

    • 示例:使用 Seaborn 绘制数据分布图。
    import seaborn as sns
    import matplotlib.pyplot as pltsns.histplot(data['Score'], bins=30, kde=True)
    plt.show()
    
  3. 相关性分析

    correlation = data.corr()
    sns.heatmap(correlation, annot=True)
    plt.show()
    
注意事项:
  • 分析应紧密围绕业务目标,避免冗余或无关分析。
  • 数据可视化可以提高结果的直观性。

4. 人工标注

人工标注用于生成有监督学习所需的数据集。高质量标注是构建模型的重要基础。

具体实现:
  1. 使用 Label Studio 配置标注任务

    • 安装与启动:
      pip install label-studio
      label-studio start
      
  2. 示例:文本分类标注

    • 在 Label Studio 中上传数据集,设置分类任务(如情感分类)。
注意事项:
  • 确保标注人员对任务有清晰的理解,提供标注标准。
  • 对复杂任务,建议进行多轮校对以提高标注一致性。

5. 数据构造

数据构造包括特征工程、数据增强和数据集划分。

具体实现:
  1. 数据划分

    from sklearn.model_selection import train_test_splittrain, test = train_test_split(data, test_size=0.2, random_state=42)
    print("训练集大小:", len(train))
    print("测试集大小:", len(test))
    
  2. 数据增强

    • 示例:图像翻转与旋转。
    from torchvision import transformstransform = transforms.Compose([transforms.RandomHorizontalFlip(),transforms.RandomRotation(10)
    ])
    augmented_image = transform(image)
    
  3. 特征工程

    • 示例:提取日期特征。
    data['Year'] = data['Date'].dt.year
    data['Month'] = data['Date'].dt.month
    
注意事项:
  • 数据增强适用于深度学习任务,需避免引入噪声。
  • 特征构造应基于业务逻辑,确保对模型有正向贡献。

流程关键点总结

步骤核心任务工具与技术
数据采集从数据源获取原始数据requestsScrapy
数据清洗提高数据质量,处理缺失与异常值PandasNumpy
数据分析挖掘数据特征,生成统计与可视化SeabornMatplotlib
人工标注标注数据,为模型提供训练集Label Studio
数据构造特征工程、数据增强、划分数据集sklearntorchvision

以上流程不仅涵盖了每个阶段的理论与实践,还为具体实现提供了代码示例,便于理解和应用!

http://www.lryc.cn/news/492029.html

相关文章:

  • Linux宝塔部署wordpress网站更换服务器IP后无法访问管理后台和打开网站页面显示错乱
  • 区块链知识体系
  • 力扣第 66 题 “加一”
  • C语言数据结构与算法--简单实现队列的入队和出队
  • 代码美学:MATLAB制作渐变色
  • 排序算法之冒泡排序篇
  • WPF ItemsControl控件
  • CentOS 上安装各种应用的命令行总结
  • Java中的JSONObject详解
  • 音视频流媒体直播/点播系统EasyDSS互联网视频云平台介绍
  • shell编程3,参数传递+算术运算
  • 自动泊车“哐哐撞大墙”,小米SU7智驾功能bug缠身?
  • RAG 与 HyDE
  • 在WPF程序中实现PropertyGrid功能
  • 【R语言管理】Pycharm配置R语言及使用Anaconda管理R语言虚拟环境
  • .Net与C#
  • 使用ElementUI中的el-table制作可编辑的表格
  • 开放性技术的面试题该如何应对?
  • Leetcode 面试150题 88.合并两个有序数组 简单
  • CGAL CGAL::Polygon_mesh_processing::self_intersections解析
  • esp32触发相机
  • webrtc支持h265
  • macos 14.0 Monoma 修改顶部菜单栏颜色
  • 在 Mac(ARM 架构)上安装 JDK 8 环境
  • Linux高阶——1123—
  • VOLO实战:使用VOLO实现图像分类任务(二)
  • 【kafka02】消息队列与微服务之Kafka部署
  • MySQL系列之数据类型(Numeric)
  • BERT简单理解;双向编码器优势
  • LLamafactory 批量推理与异步 API 调用效率对比实测