如何在matplotlib中使用下标文本进行注释?

时间:2012-11-07 11:14:40

标签: python annotations matplotlib

我试图用matplotlib绘制一些数据,我需要一些注释来形成像数学/化学公式。 这是我的一些代码。

#!/usr/bin/python2 
import numpy as np
import matplotlib.pyplot as pytl
from matplotlib import rc
rc('font',**{'family':'sans-serif','sans-serif':['Helvetica']})
rc('text', usetex=True)
recdt = np.dtype([('compound',str,4),('H_v','f4'),('B_o','f4')]);
gat =  np.loadtxt('tra',dtype=object, usecols=(0,1,2),unpack=True);
gct,ght,gbt=[],[],[]
for c,h,b in np.transpose(gat):
    gct=np.append(gct,c)
    ght=np.append(ght,h)
    gbt=np.append(gbt,b)
ght= ght.astype(np.float)
gbt= gbt.astype(np.float)
hard = pytl
four = hard   #####  
four.scatter(gbt,ght)
hard.title( 'physical stuff' )
hard.xlabel('physical prop 1')
hard.ylabel('physical prop2 ')
for l,x1,y2 in zip ( gct,gbt,ght):
    hard.annotate( l,xy=(x1,y2),xytext=(-24,12),textcoords = 'offset points', arrowprops = dict(arrowstyle = '->', connectionstyle = 'arc3,rad=0'),rotation=0 )
hard.ylim([0,10])
hard.savefig('hardcomp.png')
hard.show()

这是一些测试数据

ZrC 6.8 1
NbC 8   2
NbN 7   13
RuB2    30  5
BP  3   1
AlP 9.4 3
InSb    2.2 47
C   6   4

数据在三列中一个文本,另外两个是数字。 我希望'RbB2'中的'2'最终作为下标。

1 个答案:

答案 0 :(得分:5)

我们可以使用2表示法'RbB2'TeX $\tt{RbB_{2}}$中显示下标c。在代码中,您只需修改import re for c,h,b in np.transpose(gat): c = r'$\tt{{{c}}}$'.format(c = re.sub(r'(\d+)',r'_{\1}', c))

import re
import numpy as np
import matplotlib.pyplot as pytl
from matplotlib import rc

rc('font', **{'family':'sans-serif', 'sans-serif':['Helvetica']})
rc('text', usetex = True)
recdt = np.dtype([('compound', str, 4), ('H_v', 'f4'), ('B_o', 'f4')]);
gat =  np.loadtxt('tra', dtype = object, usecols = (0, 1, 2), unpack = True);
gct, ght, gbt = [], [], []
for c, h, b in np.transpose(gat):
    c = r'$\tt{{{c}}}$'.format(c = re.sub(r'(\d+)', r'_{\1}', c))
    gct = np.append(gct, c)
    ght = np.append(ght, h)
    gbt = np.append(gbt, b)
ght = ght.astype(np.float)
gbt = gbt.astype(np.float)
hard = pytl
four = hard   #####  
four.scatter(gbt, ght)
hard.title( 'physical stuff' )
hard.xlabel('physical prop 1')
hard.ylabel('physical prop2 ')
for l, x1, y2 in zip ( gct, gbt, ght):
    print(l, x1, y2)
    hard.annotate(
        l, xy = (x1, y2), xytext = (-24, 12), textcoords = 'offset points',
        arrowprops = dict(arrowstyle = '->', connectionstyle = 'arc3,rad=0'),
        rotation = 0 )
hard.ylim([0, 10])
hard.savefig('hardcomp.png')
hard.show()

产生

enter image description here


{{1}}