Python绘制地球化学三角投图、梯形图、任意多边形图

发布时间:2024年01月12日
  • 示例图片:
    地球化学三角投图、梯形图、任意多边形图
  • 数据准备:
    示例数据
  • 主要模块:pandas、matplotlib、mpltern
  • 模块安装
pip install pandas matplotlib mpltern
  • 完整代码:
# ************************************************************************
# _*_coding:utf-8_*_
# Author: Pandas120 (微信)
# Desription: 绘制地球化学三角投图、梯形图、任意多边形图
# ************************************************************************
import matplotlib.pyplot as plt
import mpltern
import pandas as pd
from matplotlib.ticker import MultipleLocator
plt.rcParams['font.family'] = 'Arial Unicode MS'
plt.rcParams['font.size'] = 10
plt.rcParams["pdf.fonttype"] = 42


data = pd.read_excel('Py-data.xlsx')

#创建画布大小
fig = plt.figure(figsize=(6,4))
#ternary_sum设置刻度范围最大值
ax = plt.subplot(projection='ternary',ternary_sum=100.0)
#绘制散点
pc = ax.scatter(data['Fs'], data['Wo'], data['En'],label='samples')
#绘制内部网格
ax.grid()

#截取顶部,绘制任意多边形修改下面参数范围即可
ax.set_ternary_lim(
    0, 50,  # rmin, rmax
    0, 100,  # lmin, lmax
    0, 100,  # bmin, bmax
)
#设置三元
ax.set_tlabel("Fs")
ax.set_llabel("Wo")
ax.set_rlabel("En")
#设置刻度
ax.taxis.set_major_locator(MultipleLocator(10))
ax.laxis.set_major_locator(MultipleLocator(10))
ax.raxis.set_major_locator(MultipleLocator(10))
#设置图例位置
ax.legend(loc=1)
plt.tight_layout()
fig.savefig('2.pdf')
plt.show()
文章来源:https://blog.csdn.net/lili_2014/article/details/135539103
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。