码迷,mamicode.com
首页 > 其他好文 > 详细

matplotlib的初次使用

时间:2018-05-04 01:35:33      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:with open   tin   figure   idt   coding   字典   src   sub   分享图片   

初次尝试python的matplotlib,因为论文有一堆数据要处理,只能自学。就是所谓的用到什么学什么吧。

下面记录一下:首先统计所有阈值的频率,用dictionary来存储;参考官方网址对plt.bar()的各个参数解释,建立相应的柱状图。

代码如下:

# encoding:utf-8
import numpy as np
import math
from matplotlib import pyplot as plt

# 0的字典
dic0 = {}
# 1的字典
dic1 = {}

def autolabel(rects):
    for rect in rects:
        height = rect.get_height()
        plt.text(rect.get_x() + rect.get_width() / 2. - 0.2, 1.03 * height, ‘%d‘ % height)

total_width,n = 0.4,2
width = total_width/n

with open(r‘/Users/binryang/Desktop/运行结果/balloons_qp25_16.txt‘, ‘r‘) as f:
    for line in f:
        a = line.split()
        key = int(math.ceil(float(a[1])))
        if key == 0 or key > 10:
            continue
        if a[0] == ‘0‘:
            if key in dic0.keys():
                dic0[key] = dic0[key] + 1
            else:
                dic0[key] = 1
        else:
            if key+width in dic1.keys():
                dic1[key+width] = dic1[key+width] + 1
            else:
                dic1[key+width] = 1


# items0 = dic0.items()
# items0.sort()
#
# items1 = dic1.items()
# items1.sort()
#
# print dic0
# print dic1

# plt.figure()
# plt.plot(dic0.keys(),dic0.values())
# plt.plot(dic1.keys(),dic1.values())

m = plt.bar(dic0.keys(), dic0.values(),width,label=‘no-division‘)
n = plt.bar(dic1.keys(),dic1.values(),width,label=‘division‘)
autolabel(m)
autolabel(n)
plt.xlabel(‘difference value‘)
plt.ylabel(‘numbers‘)
plt.title(‘numbers of difference value‘)
plt.legend()

# plt.xticks(dic0.keys())

# plt.subplot(212)
# plt.bar(dic1.keys(),dic1.values())
# plt.xlabel(‘difference value‘)
# plt.ylabel(‘numbers‘)
# plt.xticks(dic1.keys())
plt.savefig(‘bar.pdf‘)
plt.show()

生成的图片如下:
技术分享图片

吐槽一下:插入图片不能用pdf,导致放大失真严重

matplotlib的初次使用

标签:with open   tin   figure   idt   coding   字典   src   sub   分享图片   

原文地址:https://www.cnblogs.com/bingo2-here/p/8988098.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!