【python】python油田数据分析与可视化(源码+数据集)【独一无二】

embedded/2025/2/4 1:54:03/

请添加图片描述


👉博__主👈:米码收割机
👉技__能👈:C++/Python语言
👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。


pythonpython_11">【pythonpython油田数据分析与可视化(源码+数据集)【独一无二】


目录

  • pythonpython油田数据分析与可视化(源码+数据集)【独一无二】
  • 一、设计要求
  • 二、设计思路
      • **油田数据分析与可视化——设计思路**
        • **1. 项目背景**
        • **2. 代码结构分析**
    • **第一步:数据读取**
      • **1.1 读取各油田数据**
    • **第二步:数据预处理**
      • **2.1 转换日期格式**
      • **2.2 计算总产液量**
      • **2.3 计算各井的平均日产液量/注水量**
      • **2.4 合并井位信息**
    • **第三步:数据可视化**
      • **3.1 井位分布散点图**
      • **3.2 产量变化趋势折线图**
      • **3.3 产量对比条形图**
      • **3.4 产量构成饼图**
      • **3.5 单井日产量分布直方图**
    • **第四步:数据导出**


一、设计要求

本项目旨在开发一个 油田数据分析与可视化系统,实现 数据读取、清洗、统计分析、可视化展示数据导出 功能。系统支持读取 产量、井位、注水 数据,进行格式标准化、缺失值处理及衍生变量计算,并通过 井位分布图、趋势折线图、对比条形图、饼图、直方图 展示数据分析结果。同时,支持数据导出为 Excel,提高数据管理和决策效率。采用 Python(pandas、matplotlib、numpy) 开发,优化大规模数据处理,确保计算高效、可视化直观,并具备未来扩展为 Web 平台或 AI 预测系统的潜力。

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述


二、设计思路

油田数据分析与可视化——设计思路

1. 项目背景

本项目的目标是对油田数据进行清洗、分析,并以可视化方式呈现油井的分布情况、产量变化趋势及统计特征。数据源主要包括不同油田的 产量数据井位数据注水数据,最终通过 Matplotlib 进行可视化展示。

2. 代码结构分析

整个代码可以分为以下几个主要步骤:

  1. 数据读取
  2. 数据预处理
  3. 数据可视化
  4. 数据导出(可选)

在这里插入图片描述

第一步:数据读取

该部分的主要任务是加载不同油田的CSV数据文件,使用 pandas 读取数据集,并存入 DataFrame 进行后续处理。

1.1 读取各油田数据

数据主要分为以下几类:

  • JL油田
    • JL油田-近期产量数据.csv(包含日产油量、日产水量、日产气量)
    • JL油田-井位井别.csv(包含井的坐标、采油井/注水井类别)
    • JL油田-注水数据.csv(包含日注水量)
  • ML油田
    • ML油田-井位井别.csv(井位信息)
    • ML油田-注水数据.csv(仅有注水量,无产油产水数据)
  • WL油田
    • WL油田-近期产量数据.csv
    • WL油田-井位井别.csv
    • WL油田-注水数据.csv

实现方式

python">df_jl_prod = pd.read_csv("JL油田-近期产量数据.csv")  
# 代码略....

第二步:数据预处理

数据预处理的核心目标是确保数据格式一致,填充缺失值,并计算衍生变量。例如:

  1. 转换日期格式
  2. 计算总产液量
  3. 计算各井的平均日产液量/注水量
  4. 合并不同数据表

2.1 转换日期格式

确保 日期 字段是 datetime 格式,以便后续时间序列分析:

python">df_jl_prod['日期'] = pd.to_datetime(df_jl_prod['日期'])
df_jl_inj['日期'] = pd.to_datetime(df_jl_inj['日期'])

2.2 计算总产液量

python">df_jl_prod['产液量'] = df_jl_prod['日产油量'] + df_jl_prod['日产水量']

此计算反映了井的 总液体产出(油 + 水),用于衡量单井或油田的生产能力。

2.3 计算各井的平均日产液量/注水量

对于采油井,计算 平均日产液量

python">jl_prod_group = df_jl_prod.groupby('井名', as_index=False)['产液量'].mean()
jl_prod_group.rename(columns={'产液量': '平均日产液量'}, inplace=True)

对于注水井,计算 平均日注水量

python">jl_inj_group = df_jl_inj.groupby('井名', as_index=False)['日注水量'].mean()
jl_inj_group.rename(columns={'日注水量': '平均日注水量'}, inplace=True)

在这里插入图片描述

2.4 合并井位信息

将井位数据与计算出的 日产液量/注水量 进行合并,确保绘制散点图时每个井的数值信息完整:

python">df_jl_loc['平均日产液量/注水量'] = 0.0
for i in range(len(df_jl_loc)):well = df_jl_loc.loc[i, '井名']cate = df_jl_loc.loc[i, '注采类别:1采油井;0注水井']if cate == 1:  # 代码略....else:  val = jl_inj_group[jl_inj_group['井名'] == well]['平均日注水量']if not val.empty:df_jl_loc.loc[i, '平均日产液量/注水量'] = val.values[0]

第三步:数据可视化

数据可视化分为以下几类:

  1. 井位分布散点图

  2. 产量变化趋势折线图

  3. 产量对比条形图

  4. 产量构成饼图

  5. 单井日产量分布直方图


3.1 井位分布散点图

以散点图展示井的地理位置,颜色区分 采油井/注水井,点的大小表示产量或注水量:

python">plt.scatter(df_jl_loc['X'], df_jl_loc['Y'], s=df_jl_loc['平均日产液量/注水量'] * 50, c=df_jl_loc['注采类别:1采油井;0注水井'], cmap='coolwarm', alpha=0.6)

在这里插入图片描述

3.2 产量变化趋势折线图

绘制 不同油田的日产油、日产水、日产气、日注水量随时间变化

python">plt.plot(jl_daily['日期'], jl_daily['日产油量'], marker='o', label='日产油量')
plt.plot(jl_daily['日期'], jl_daily['日产水量'], marker='s', label='日产水量')
plt.plot(jl_daily['日期'], jl_daily['日产气量'], marker='^', label='日产气量')
plt.plot(jl_daily['日期'], jl_daily['日注水量'], marker='d', label='日注水量')

在这里插入图片描述
在这里插入图片描述

3.3 产量对比条形图

绘制 不同油田的总产量

python">plt.bar(x - 1.5*width, oil_data, width, label='总产油量')
plt.bar(x - 0.5*width, water_data, width, label='总产水量')
plt.bar(x + 0.5*width, gas_data, width, label='总产气量')
plt.bar(x + 1.5*width, inj_data, width, label='总注水量')

在这里插入图片描述

3.4 产量构成饼图

展示 不同油田的产油/产水/产气比例

python">plt.pie(jl_values, labels=jl_labels, autopct='%1.1f%%', startangle=140)

在这里插入图片描述

3.5 单井日产量分布直方图

展示 单井日产油量/日注水量的分布

python">plt.hist(df_jl_prod['日产油量'], bins=10, color='orange', alpha=0.7, edgecolor='black')

在这里插入图片描述


第四步:数据导出

最终结果可保存为 Excel:

python">df_jl_prod.to_excel("油田数据汇总.xlsx", sheet_name="JL产量数据", index=False)

该代码实现了 油田数据分析与可视化,涵盖 数据清洗、统计计算、图表展示,有助于油田生产管理和决策支持。
在这里插入图片描述


http://www.ppmy.cn/embedded/159340.html

相关文章

系统思考—决策

“人类理性是有限的,我们在复杂的世界中做出决策时,往往采用简化的模型。”——贝尔经济学奖得主赫伯特西蒙 面对复杂问题,我们往往没有足够的信息、时间或精力去做出完美决策,于是,我们依赖经验法则、直觉判断&#…

RabbitMQ5-死信队列

目录 死信的概念 死信的来源 死信实战 死信之TTl 死信之最大长度 死信之消息被拒 死信的概念 死信,顾名思义就是无法被消费的消息,一般来说,producer 将消息投递到 broker 或直接到queue 里了,consumer 从 queue 取出消息进…

一文了解性能优化的方法

背景 在应用上线后,用户感知较明显的,除了功能满足需求之外,再者就是程序的性能了。因此,在日常开发中,我们除了满足基本的功能之外,还应该考虑性能因素。关注并可以优化程序性能,也是体现开发能…

Spring Boot项目如何使用MyBatis实现分页查询

写在前面:大家好!我是晴空๓。如果博客中有不足或者的错误的地方欢迎在评论区或者私信我指正,感谢大家的不吝赐教。我的唯一博客更新地址是:https://ac-fun.blog.csdn.net/。非常感谢大家的支持。一起加油,冲鸭&#x…

小红的合数寻找

A-小红的合数寻找_牛客周赛 Round 79 题目描述 小红拿到了一个正整数 x,她希望你在 [x,2x] 区间内找到一个合数,你能帮帮她吗? 一个数为合数,当且仅当这个数是大于1的整数,并且不是质数。 输入描述 在一行上输入一…

Jason配置环境变量

jason官网 https://jason-lang.github.io/ https://github.com/jason-lang/jason/releases 步骤 安装 Java 21 或更高版本 安装 Visual Studio Code 根据操作系统,请按照以下具体步骤操作 视窗 下载 Jason 的最新版本,选择“jason-bin-3.3.0.zip”…

宝塔面板SSL加密访问设置教程

参考:https://www.bt.cn/bbs/thread-117246-1-1.html 如何快速使用证书加密访问面板 因早期默认未开启https访问所以没有相关的风险提醒,现面板默认已开启https加密访问、提升安全性 由于采用的是服务器内部本身签发证书,不被公网浏览器信任请参考以下步…

STM32 DMA数据转运

DMA简介 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设和存储器或者存储器和存储器之间的高速数据传输,无须CPU干预,节省了CPU的资源 12个独立可配置的通道: DMA1(7个通道)&#xf…