降雨-径流过程图

import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
# 读取Excel文件
df = pd.read_excel(r'C:\Users\Admin\Desktop\东湾.xlsx', sheet_name='测试')
# 将日期列转换为日期格式
df['日期'] = pd.to_datetime(df['日期'])
# 提取实测流量和模拟流量数据
true = df['流量']
sim = df['测试3']
pre = df['雨量']
# 创建一个新的图形和轴对象
fig, ax1 = plt.subplots(figsize=(10, 6))
plt.rcParams['font.sans-serif'] = 'SimHei'  # 设置中文显示
# 绘制实测流量折线
ax1.plot(df['日期'], true, label='实测流量', marker='.', linestyle='--', color='blue')
# 绘制模拟流量折线
ax1.plot(df['日期'], sim, label='模拟流量', color='orange')
# 设置第一个y轴标签和颜色
ax1.set_ylabel('流量/($m^3·s^{-1}$)', color='black')
ax1.tick_params(axis='y', labelcolor='black', direction='in')
# 设置主y轴范围
ax1.set_ylim(0, 500)
# 创建第二个y轴对象,共享x轴
ax2 = ax1.twinx()
# 绘制雨量柱状图
ax2.bar(df['日期'], pre, label='雨量', alpha=0.5, color='blue', width=2)
# 设置第二个y轴标签和颜色
ax2.set_ylabel('雨量/(mm)', color='black')
ax2.tick_params(axis='y', labelcolor='black', direction='in')
# 设置次y轴范围并倒置
ax2.set_ylim(100, 0)
# 设置x轴日期刻度为1年为间隔
ax1.xaxis.set_major_locator(mdates.YearLocator(1))
# 设置x轴刻度线向内
ax1.tick_params(axis='x', direction='in')
# 合并图例
lines, labels = ax1.get_legend_handles_labels()
lines2, labels2 = ax2.get_legend_handles_labels()
ax2.legend(lines + lines2, labels + labels2, loc='upper center', bbox_to_anchor=(0.5, -0.06), ncol=3, frameon=False)  # 调整bbox_to_anchor参数

# 设置整个图形的xlabel
fig.text(0.5, 0.06, '年份', ha='center', va='center')
plt.title('降雨-径流图')
# 显示图形
plt.show()

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Peanut-uu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值