-
示例图片:
地球化学三角投图、梯形图、任意多边形图 -
数据准备:
示例数据 - 主要模块: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()

