利用python matplotlib进行绘图时,经常苦恼于无法一键对图片格式进行调整以满足常见期刊论文图片格式要求。通常会要求300dpi,半栏宽度为7cm,跨栏宽度为14cm,线条能看清,字体略小于正文字体,X轴刻度为整数...等等
在网页上查询相关内容都比较复杂,我就只想绘个图,你给我弄上几十个选项或者十几行代码让我填?看着都头大。经过几天的摸索,可一键进行上述设置的方法来了!!后附自编函数,图片经设置并保存后,不用调整大小,可直接放在论文中使用。
1.主要的设置项
在matplotlib.pyplot中,有一个名为 rcParams 的选项,该参数可以完成几乎所有你想进行的图片格式预设置。
废话不多说,直接上代码,rcParams 能进行设置的'keys'参数可通过如下代码进行查看:
import matplotlib.pyplot as plt
plt.rcParams.keys()
结果如下,可以看出其几乎涵盖了你所能想到的所有参数(一共300+项,为节约空间,仅展示部分内容)。
后面本人将根据RcParams选项进行图片格式参数一键设置函数的编写。
KeysView(RcParams({'_internal.classic_mode': False,
'axes.autolimit_mode': 'data',
'axes.axisbelow': 'line',
'axes.edgecolor': 'black',
'axes.facecolor': 'white',
'axes.grid': False,
'axes.grid.axis': 'both',
'axes.grid.which': 'major',
'axes.labelcolor': 'black',
'axes.labelpad': 4.0,
'axes.labelsize': 7.0,
'axes.labelweight': 'normal',
'axes.linewidth': 1.0,
'figure.dpi': 300.0,
'figure.edgecolor': 'white',
'figure.facecolor': 'white',
'figure.figsize': [2.755905511811023, 2.3622047244094486],
'figure.frameon': True,
'figure.max_open_warning': 20,
'figure.subplot.bottom': 0.11,
'figure.subplot.hspace': 0.2,
'figure.subplot.left': 0.125,
'figure.subplot.right': 0.9,
'figure.subplot.top': 0.88,
'figure.subplot.wspace': 0.2,
'figure.titlesize': 'large',
'figure.titleweight': 'normal',
'font.sans-serif': ['SimHei'],
'font.size': 10.0,
'font.stretch': 'normal',
'font.style': 'normal',
'font.variant': 'normal',
'font.weight': 'light',
'legend.loc': 'best',
'legend.markerscale': 1.0,
'legend.numpoints': 1,
'legend.scatterpoints': 1,
'legend.shadow': False,
'legend.title_fontsize': None,
'xtick.alignment': 'center',
'xtick.bottom': True,
'xtick.color': 'black',
'xtick.direction': 'in',
'xtick.labelbottom': True,
'xtick.labelsize': 7.0,
'xtick.labeltop': False,
'xtick.top': False,
'ytick.alignment': 'center_baseline',
'ytick.color': 'black',
'ytick.direction': 'in',
'ytick.labelleft': True,
'ytick.labelright': False,
'ytick.labelsize': 7.0,
'ytick.left': True,
'ytick.right': False}))
2.参数设置函数(论文可以直接用)
下面给出了本人编写的函数,用法如下:
1.在绘图前运行fig=setfig(column=1)实例
2.绘图
3.绘图后运行fig.show()
layout相关的设置必须在图片画好后才能进行,这一点让人很无奈。代码最后面给出了主函数运行的案例,直接运行当前函数可以进行体验。线条大小、字体大小等已经过个人测试,若需要改动可在对应的位置进行调整。
# _*_coding: UTF-8_*_
# 开发作者 :TXH
# 开发时间 :2020.07.02
# 文件名称 :setfig1.py
# 开发工具 :Python 3.6 + Pycharm IDE
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import font_manager,ticker
class setfig():
'''
在绘图前对字体类型、字体大小、分辨率、线宽、输出格式进行设置.
para colume = 1.半栏图片 7*6cm
2.双栏长图 14*6cm
x轴刻度默认为整数
手动保存时,默认输出格式为 pdf
案例 Sample.1:
fig=setfig(column=2)
plt.semilogy(x, color='blue', linestyle='solid', label='信号1')
plt.legend(loc='upper left')
plt.xlabel('时间/t')
plt.ylabel('幅度')
plt.title('冲击声信号')
fig.show()
'''
def __init__(self,column):
self.column = column # 设置栏数
# 对尺寸和 dpi参数进行调整
plt.rcParams['figure.dpi'] = 300
# 字体调整
plt.rcParams['font.sans-serif'] = ['simhei'] # 如果要显示中文字体,则在此处设为:simhei,Arial Unicode MS
plt.rcParams['font.weight'] = 'light'
plt.rcParams['axes.unicode_minus'] = False # 坐标轴负号显示
plt.rcParams['axes.titlesize'] = 8 # 标题字体大小
plt.rcParams['axes.labelsize'] = 7 # 坐标轴标签字体大小
plt.rcParams['xtick.labelsize'] = 7 # x轴刻度字体大小
plt.rcParams['ytick.labelsize'] = 7 # y轴刻度字体大小
plt.rcParams['legend.fontsize'] = 6
# 线条调整
plt.rcParams['axes.linewidth'] = 1
# 刻度在内,设置刻度字体大小
plt.rcParams['xtick.direction'] = 'in'
plt.rcParams['ytick.direction'] = 'in'
# 设置输出格式为PDF
plt.rcParams['savefig.format'] = 'pdf'
plt.rcParams['figure.autolayout'] = True
@property
def tickfont(self):
plt.tight_layout()
ax1 = plt.gca() # 获取当前图像的坐标轴
# 更改坐标轴字体,避免出现指数为负的情况
tick_font = font_manager.FontProperties(family='it', size=7.0)
ax1.xaxis.set_major_locator
for labelx in ax1.get_xticklabels():
labelx.set_fontproperties(tick_font)
for labely in ax1.get_yticklabels():
labely.set_fontproperties(tick_font)
ax1.xaxis.set_major_locator(ticker.MaxNLocator(integer=True)) # x轴刻度设置为整数
@property
def Global_font(self):
# 设置基本字体
plt.rcParams['font.sans-serif'] = ['simhei'] # 如果要显示中文字体,则在此处设为:simhei,Arial Unicode MS
plt.rcParams['font.weight'] = 'light'
def show(self):
# 改变字体
self.Global_font
self.tickfont
# 改变图像大小
cm_to_inc = 1 / 2.54 # 厘米和英寸的转换 1inc = 2.54cm
gcf = plt.gcf() # 获取当前图像
if self.column==1:
gcf.set_size_inches(7 * cm_to_inc, 6 * cm_to_inc)
else:
gcf.set_size_inches(14 * cm_to_inc, 6 * cm_to_inc)
plt.show()
if __name__=='__main__':
# 生成信号1,共6个模态
Ts = 0.0002
t = Ts*np.array(range(89)).reshape(-1,1) #采样时间序列
x = np.exp(1j * (2 * np.pi * 1325 * t + 1 * np.pi / 6)) * np.exp(0.5 * t) + 0.88 * np.exp(
1j * (2 * np.pi * 1450 * t + 2 * np.pi / 6)) + 1.5 * np.exp(1j * (2 * np.pi * 1500 * t + 3 * np.pi / 6)) + \
0.7 * np.exp(1j * (2 * np.pi * 1535 * t + 4 * np.pi / 6)) + 3 * np.exp(
1j * (2 * np.pi * 1550 * t + 5 * np.pi / 6)) \
+ 0.2 * np.exp(1j * (2 * np.pi * 2000 * t + np.pi))
x = np.exp(x)
plt.close('all')
fig=setfig(column=2)
plt.plot(x * 2, color='red', linestyle='dashed', label='信号2')
plt.legend(loc='upper left')
plt.xlabel('时间 $/t_2$')
plt.ylabel('幅度 $\zeta_1$') # mathtext 可用
plt.title('冲击声信号')
plt.xlim(0, 20) # 设置x轴范围
plt.ylim(0, 20) # 设置y轴范围
fig.show()
plt.figure()
plt.semilogy(x, color='blue', linestyle='solid', label='信号$\zeta$')
plt.legend(loc='upper left')
plt.xlabel(r'时间$/t_1$')
plt.ylabel(r'幅度$\alpha\theta$')
plt.title(r'冲击声信号$\alpha\theta$')
fig.show()
# plt.savefig('figures/J.png', format='png') # 建议保存为svg格式,再用inkscape转为矢量图emf后插入word中