python绘制有误差线的折线图

数据示意
数据如上

"""
author: Shuai-jie Shen 沈帅杰
优快云: https://blog.youkuaiyun.com/weixin_45452300
公众号: AgBioIT
"""
import pandas as pd
import numpy as np
import matplotlib
matplotlib.rcParams['backend'] = 'SVG'
import matplotlib.pyplot as plt
import matplotlib.font_manager as fm
#读取数据
data = pd.read_excel(r'C:\Users\Administrator\Desktop\图(1).xlsx',sheet_name = 2)
std_table = data.groupby(by = '上层光截获').std() # 计算标准差
figdata = data.groupby(by = '上层光截获').mean() #计算均值
# 绘图
# 标记样式常用的值有(./,/o/v/^/s/*/D/d/x/</>/h/H/1/2/3/4/_/|)https://www.jianshu.com/p/b992c1279c73,参考
plt.errorbar(figdata.columns,figdata.loc['R1D1'],yerr=std_table.loc['R1D1'],fmt='k-o',lw = 2,ecolor='k',elinewidth=1,ms=7,capsize=3) 
plt.errorbar(figdata.columns,figdata.loc['R1D2'],yerr=std_table.loc['R1D2'],fmt='k-x',lw = 2,ecolor='k',elinewidth=1,ms=7,capsize=3)
plt.errorbar(figdata.columns,figdata.loc['R1D3'],yerr=std_table.loc['R1D3'],fmt='k-d',lw = 2,ecolor='k',elinewidth=1,ms=7,capsize=3)
plt.errorbar(figdata.columns,figdata.loc['R2D1'],yerr=std_table.loc['R2D1'],fmt='k-s',lw = 2,ecolor='k',elinewidth=1,ms=7,capsize=3)
plt.errorbar(figdata.columns,figdata.loc['R2D2'],yerr=std_table.loc['R2D2'],fmt='k-h',lw = 2,ecolor='k',elinewidth=1,ms=7,capsize=3)
plt.errorbar(figdata.columns,figdata.loc['R2D3'],yerr=std_table.loc['R2D3'],fmt='k-^',lw = 2,ecolor='k',elinewidth=1,ms=7,capsize=3)
# 设置坐标轴标签文本
Songti = fm.FontProperties(fname='C:\Windows\Fonts\simsun.ttc') #创建宋体
plt.xlabel('growth stage\n生育时期', fontproperties=Songti, fontsize=14)
plt.ylabel('上层光截获\nUpper light interception', fontproperties=Songti, fontsize=14)
# 创建字体,设置图例 windows自带字体路径
myfont = fm.FontProperties(fname=r'C:\Windows\Fonts\STKAITI.ttf',
                           size=10)
plt.legend(prop=myfont, fontsize=19,ncol=2)
plt.tight_layout() #防止保存时大小不合适
plt.savefig(r'C:\Users\Administrator\Desktop\{}.jpg'.format('Upper light interception'), dpi=400)
plt.savefig(r'C:\Users\13290\Desktop\{}light interception.svg'.format(name[i]), format='svg') #  存为矢量图
plt.show()

结果
结果

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值