zoukankan      html  css  js  c++  java
  • python--Matplotlib(二)

    Matplotlib+pandas作图

    一、对csv文件进行提取ruixi.csv

    对上述表格进行提取并做图

    #-*- coding:utf-8 -*-
    import matplotlib as mpl
    import numpy as np
    import pandas as pd
    import matplotlib.pyplot as plt
    import pdb
    
    df = pd.read_csv("ruixi.csv")
    df1 = df.loc[:20,['trackid','playc']]
    #对playc列的值从大到小排序
    df2 = df1.sort_values(by='playc',ascending=False)
    #mpl.rcParams['font.sans-serif'] = ['Microsoft YaHei'] # 指定默认字体
    
    df2.plot(kind='bar',x='trackid',y='playc',alpha=0.6)
    '''
    首先,前边设置的x、y值其实就代表了不同柱子在图形中的位置(坐标),通过for循环找到每一个x、y值的相应坐标——a、b,
    再使用plt.text在对应位置添文字说明来生成相应的数字标签,而for循环也保证了每一个柱子都有标签。
    其中,a, b+0.05表示在每一柱子对应x值、y值上方0.05处标注文字说明, '%.0f' % b,代表标注的文字,
    即每个柱子对应的y值, ha='center', va= 'bottom'代表horizontalalignment(水平对齐)、verticalalignment(垂直对齐)的方式,
    fontsize则是文字大小
    '''
    x = df2['trackid']
    y = df2['playc']
    for a,b in zip(x,y):
        plt.text(a, b,'%.0f'%b,fontdict={'size': 5, 'color': 'r'})
    
    plt.xlabel("trackId")
    plt.ylabel("playc")
    plt.title("ruixi")
    
    plt.show()

    画出图像

     二、对.xlsx进行提取:ruixi.xlsx

     

    #-*- coding:utf-8 -*-
    import matplotlib as mpl
    import numpy as np
    import pandas as pd
    import matplotlib.pyplot as plt
    import pdb
    
    df = pd.read_excel("ruixi.xlsx")
    df.columns=['trackid','title','playc']
    df2 = df.loc[:30,['title','playc']]
    df2.sort_values(by='playc',ascending=False)
    df2.plot(kind='bar',x='title',y='playc',alpha=0.6)
    
    plt.xlabel("trackId")
    plt.ylabel("playc")
    plt.title("ruixi")
    plt.show()
  • 相关阅读:
    [IDEA]高级用法
    [TongEsb]Windows入门教程
    [MAC] JDK版本切换
    [下划线]换行自适应稿纸完美方案
    [IDEA] Jrebel热部署环境搭建Mac
    Python规范:用用assert
    Python规范:提高可读性
    Python规范:代码规范要注意
    计算机网络自顶向下方法--计算机网络中的安全.2
    Python进阶:程序界的垃圾分类回收
  • 原文地址:https://www.cnblogs.com/eilinge/p/9854551.html
Copyright © 2011-2022 走看看