无用之学matplotlib,numpy,pandas
一、matplotlib学习
matplotlib: 最流行的Python底层绘图库,主要做数据可视化图表,名字取材于MATLAB,模仿MATLAB构建
例子1:
# coding=utf-
from matplotlib import pyplot as plt x = range(,,)
y = [,,14.5,,,,,,,,,] #设置图片大小
plt.figure(figsize=(,),dpi=) #绘图
plt.plot(x,y) #设置x轴的刻度
_xtick_labels = [i/ for i in range(,)]
plt.xticks(range(,))
plt.yticks(range(min(y),max(y)+)) #保存
# plt.savefig("./t1.png") #展示图形
plt.show()
图片如下
例子2
# coding=utf-
from matplotlib import pyplot as plt
import random
import matplotlib
from matplotlib import font_manager #windws和linux设置字体的放
# font = {'family' : 'MicroSoft YaHei',
# 'weight': 'bold',
# 'size': 'larger'}
# matplotlib.rc("font",**font)
# matplotlib.rc("font",family='MicroSoft YaHei',weight="bold") #另外一种设置字体的方式
my_font = font_manager.FontProperties(fname="/System/Library/Fonts/PingFang.ttc") x = range(,)
y = [random.randint(,) for i in range()] plt.figure(figsize=(,),dpi=) plt.plot(x,y) #调整x轴的刻度
_xtick_labels = ["10点{}分".format(i) for i in range()]
_xtick_labels += ["11点{}分".format(i) for i in range()]
#取步长,数字和字符串一一对应,数据的长度一样
plt.xticks(list(x)[::],_xtick_labels[::],rotation=,fontproperties=my_font) #rotaion旋转的度数 #添加描述信息
plt.xlabel("时间",fontproperties=my_font)
plt.ylabel("温度 单位(℃)",fontproperties=my_font)
plt.title("10点到12点每分钟的气温变化情况",fontproperties=my_font) plt.show()
例子3
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager my_font = font_manager.FontProperties(fname="C:\\Windows\\Fonts\\STHUPO.ttf") y = [,,,,,,,,,,,,,,,,,,,]
x = range(,) #设置图形大小
plt.figure(figsize=(,),dpi=) plt.plot(x,y) #设置x轴刻度
_xtick_labels = ["{}岁".format(i) for i in x]
plt.xticks(x,_xtick_labels,fontproperties=my_font)
plt.yticks(range(,)) #绘制网格
plt.grid(alpha=0.1) #展示
plt.show()
例子4
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager my_font = font_manager.FontProperties(fname="C:\\Windows\\Fonts\\STHUPO.ttf") y_1 = [,,,,,,,,,,,,,,,,,,,]
y_2 = [,,,,,,,,, ,,,,,,,,,,] x = range(,) #设置图形大小
plt.figure(figsize=(,),dpi=) plt.plot(x,y_1,label="自己",color="#F08080")
plt.plot(x,y_2,label="同桌",color="#DB7093",linestyle="--") #设置x轴刻度
_xtick_labels = ["{}岁".format(i) for i in x]
plt.xticks(x,_xtick_labels,fontproperties=my_font)
# plt.yticks(range(,)) #绘制网格
plt.grid(alpha=0.4,linestyle=':') #添加图例
plt.legend(prop=my_font,loc="upper left") #展示
plt.show()
例子5
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager my_font = font_manager.FontProperties(fname="C:\\Windows\\Fonts\\STHUPO.ttf")
y_3 = [,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,]
y_10 = [,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,] x_3 = range(,)
x_10 = range(,) #设置图形大小
plt.figure(figsize=(,),dpi=) #使用scatter方法绘制散点图,和之前绘制折线图的唯一区别
plt.scatter(x_3,y_3,label="3月份")
plt.scatter(x_10,y_10,label="10月份") #调整x轴的刻度
_x = list(x_3)+list(x_10)
_xtick_labels = ["3月{}日".format(i) for i in x_3]
_xtick_labels += ["10月{}日".format(i-) for i in x_10]
plt.xticks(_x[::],_xtick_labels[::],fontproperties=my_font,rotation=) #添加图例
plt.legend(loc="upper left",prop=my_font) #添加描述信息
plt.xlabel("时间",fontproperties=my_font)
plt.ylabel("温度",fontproperties=my_font)
plt.title("标题",fontproperties=my_font)
#展示
plt.show()
例子6
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname="C:\\Windows\\Fonts\\STHUPO.ttf") a = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",] b=[56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23] #设置图形大小
plt.figure(figsize=(,),dpi=)
#绘制条形图
plt.bar(range(len(a)),b,width=0.7)
#设置字符串到x轴
plt.xticks(range(len(a)),a,fontproperties=my_font,rotation=) plt.savefig("./movie.png") plt.show()
例子6-2
#绘制横着的条形图
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname="C:\\Windows\\Fonts\\STHUPO.ttf") a = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",] b=[56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23] #设置图形大小
plt.figure(figsize=(,),dpi=)
#绘制条形图
plt.barh(range(len(a)),b,height=0.3,color="orange")
#设置字符串到x轴
plt.yticks(range(len(a)),a,fontproperties=my_font) plt.grid(alpha=0.3)
# plt.savefig("./movie.png") plt.show()
例子7
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname="C:\\Windows\\Fonts\\STHUPO.ttf") a = ["猩球崛起3:终极之战","敦刻尔克","蜘蛛侠:英雄归来","战狼2"]
b_16 = [,,,]
b_15 = [,,,]
b_14 = [,,,] bar_width = 0.2 x_14 = list(range(len(a)))
x_15 = [i+bar_width for i in x_14]
x_16 = [i+bar_width* for i in x_14] #设置图形大小
plt.figure(figsize=(,),dpi=) plt.bar(range(len(a)),b_14,width=bar_width,label="9月14日")
plt.bar(x_15,b_15,width=bar_width,label="9月15日")
plt.bar(x_16,b_16,width=bar_width,label="9月16日") #设置图例
plt.legend(prop=my_font) #设置x轴的刻度
plt.xticks(x_15,a,fontproperties=my_font) plt.show()
例子8
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager a=[, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , ,,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , , , , , , , , , , , ,, , ] #计算组数
d = #组距
num_bins = (max(a)-min(a))//d
print(max(a),min(a),max(a)-min(a))
print(num_bins) #设置图形的大小
plt.figure(figsize=(,),dpi=)
plt.hist(a,num_bins,normed=True) #设置x轴的刻度
plt.xticks(range(min(a),max(a)+d,d)) plt.grid() plt.show()
例子9
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager interval = [,,,,,,,,,,,]
width = [,,,,,,,,,,,]
quantity = [,,,,,,,,,,,] print(len(interval),len(width),len(quantity)) #设置图形大小
plt.figure(figsize=(,),dpi=) plt.bar(range(),quantity,width=) #设置x轴的刻度
_x = [i-0.5 for i in range()]
_xtick_labels = interval+[]
plt.xticks(_x,_xtick_labels) plt.grid(alpha=0.4)
plt.show()
例子9-2
# coding=utf-
from matplotlib import pyplot as plt
from matplotlib import font_manager interval = [,,,,,,,,,,,]
width = [,,,,,,,,,,,]
quantity = [,,,,,,,,,,,] print(len(interval),len(width),len(quantity)) #设置图形大小
plt.figure(figsize=(,),dpi=) plt.bar(interval,quantity,width=width) #设置x轴的刻度 temp_d = []+ width[:-]
_x = [i-temp_d[interval.index(i)]*0.5 for i in interval] plt.xticks(_x,interval) plt.grid(alpha=0.4)
plt.show()
二、常用问题总结
应该选择那种图形来呈现数据
matplotlib.plot(x,y)
matplotlib.bar(x,y)
matplotlib.scatter(x,y)
matplotlib.hist(data,bins,normed)
xticks和yticks的设置
label和titile,grid的设置
绘图的大小和保存图片 做法流程:
明确问题 选择图形的呈现方式 准备数据 绘图和图形完善
三、推荐网址
1、matplotlib支持的图形是非常多的,如果有其他的需求,我们 可以查看一下url地址: http://matplotlib.org/gallery/index.html
2、plotly:可视化工具中的github,相比于matplotlib更加简单,图形更加漂亮,同时兼容matplotlib和pandas 使用用法:简单,照着文档写即可 文档地址: https://plot.ly/python/
3、echarts,前端框架,JS
4、seaborn
四、numpy
一个在Python中做科学计算的基础库,重在数值计算,也是大部分PYTHON科学计算库的基础库,多用于在大型、多维数组上执行数值运算
# coding=utf-
import numpy as np
import random #使用numpy生成数组,得到ndarray的类型
t1 = np.array([,,,])
print(t1)
print(type(t1)) t2 = np.array(range())
print(t2)
print(type(t2)) t3 = np.arange(,,)
print(t3)
print(type(t3)) print(t3.dtype)
print("*"*)
#numpy中的数据类型 t4 = np.array(range(,),dtype="i1")
print(t4)
print(t4.dtype) ##numpy中的bool类型
t5 = np.array([,,,,,],dtype=bool)
print(t5)
print(t5.dtype) #调整数据类型
t6 = t5.astype("int8")
print(t6)
print(t6.dtype) #numpy中的小数
t7 = np.array([random.random() for i in range()])
print(t7)
print(t7.dtype) t8 = np.round(t7,)
print(t8)
1、读取本地数据
# coding=utf-
import numpy as np us_file_path = "./youtube_video_data/US_video_data_numbers.csv"
uk_file_path = "./youtube_video_data/GB_video_data_numbers.csv" # t1 = np.loadtxt(us_file_path,delimiter=",",dtype="int",unpack=True)
t2 = np.loadtxt(us_file_path,delimiter=",",dtype="int") # print(t1)
print(t2) print("*"*) #取行
# print(t2[]) #取连续的多行
# print(t2[:]) #取不连续的多行
# print(t2[[,,]]) # print(t2[,:])
# print(t2[:,:])
# print(t2[[,,],:]) #取列
# print(t2[:,]) #取连续的多列
# print(t2[:,:]) #取不连续的多列
# print(t2[:,[,]]) #去行和列,取第3行,第四列的值
# a = t2[,]
# print(a)
# print(type(a)) #取多行和多列,取第3行到第五行,第2列到第4列的结果
#去的是行和列交叉点的位置
b = t2[:,:]
# print(b) #取多个不相邻的点
#选出来的结果是(,) (,) (,)
c = t2[[,,],[,,]]
print(c)
2、exer
# coding=utf-
import numpy as np # print(t1)
def fill_ndarray(t1):
for i in range(t1.shape[]): #遍历每一列
temp_col = t1[:,i] #当前的一列
nan_num = np.count_nonzero(temp_col!=temp_col)
if nan_num !=: #不为0,说明当前这一列中有nan
temp_not_nan_col = temp_col[temp_col==temp_col] #当前一列不为nan的array # 选中当前为nan的位置,把值赋值为不为nan的均值
temp_col[np.isnan(temp_col)] = temp_not_nan_col.mean()
return t1 if __name__ == '__main__':
t1 = np.arange().reshape((, )).astype("float")
t1[, :] = np.nan
print(t1)
t1 = fill_ndarray(t1)
print(t1)
3、exer2
import numpy as np
from matplotlib import pyplot as plt us_file_path = "./youtube_video_data/US_video_data_numbers.csv"
uk_file_path = "./youtube_video_data/GB_video_data_numbers.csv" # t1 = np.loadtxt(us_file_path,delimiter=",",dtype="int",unpack=True)
t_us = np.loadtxt(us_file_path,delimiter=",",dtype="int") #取评论的数据
t_us_comments = t_us[:,-] #选择比5000小的数据
t_us_comments = t_us_comments[t_us_comments<=] print(t_us_comments.max(),t_us_comments.min()) d = bin_nums = (t_us_comments.max()-t_us_comments.min())//d #绘图
plt.figure(figsize=(,),dpi=) plt.hist(t_us_comments,bin_nums) plt.show()
exer2-2
import numpy as np
from matplotlib import pyplot as plt us_file_path = "./youtube_video_data/US_video_data_numbers.csv"
uk_file_path = "./youtube_video_data/GB_video_data_numbers.csv" # t1 = np.loadtxt(us_file_path,delimiter=",",dtype="int",unpack=True)
t_uk = np.loadtxt(uk_file_path,delimiter=",",dtype="int") #选择喜欢书比50万小的数据
t_uk = t_uk[t_uk[:,]<=] t_uk_comment = t_uk[:,-]
t_uk_like = t_uk[:,] plt.figure(figsize=(,),dpi=)
plt.scatter(t_uk_like,t_uk_comment) plt.show()
五、pandas
1、为什么要学习pandas
那么问题来了:numpy已经能够帮助我们处理数据,能够结合matplotlib解决我们数据分析的问题,那么pandas学习的目的在什么地方呢? numpy能够帮我们处理处理数值型数据,但是这还不够
很多时候,我们的数据除了数值之外,还有字符串,还有时间序列等
比如:我们通过爬虫获取到了存储在数据库中的数据
比如:之前youtube的例子中除了数值之外还有国家的信息,视频的分类(tag)信息,标题信息等 所以,numpy能够帮助我们处理数值,但是pandas除了处理数值之外(基于numpy),还能够帮助我们处理其他类型的数据
2、
无用之学matplotlib,numpy,pandas的更多相关文章
- 绘图 Matplotlib Numpy Pandas
丈夫气力全,一个拟当千.猛气冲心出,视死亦如眠. 绘图 Matplotlib可视化是在整个数据挖掘的关键辅助工具,可以清晰的理解数据,从而调整我们的分析方法. 能将数据进行可视化,更直观的呈现使数据更 ...
- python 数据分析工具之 numpy pandas matplotlib
作为一个网络技术人员,机器学习是一种很有必要学习的技术,在这个数据爆炸的时代更是如此. python做数据分析,最常用以下几个库 numpy pandas matplotlib 一.Numpy库 为了 ...
- 第一章:AI人工智能 の 数据预处理编程实战 Numpy, Pandas, Matplotlib, Scikit-Learn
本课主题 数据中 Independent 变量和 Dependent 变量 Python 数据预处理的三大神器:Numpy.Pandas.Matplotlib Scikit-Learn 的机器学习实战 ...
- linux下安装numpy,pandas,scipy,matplotlib,scikit-learn
python在数据科学方面需要用到的库: a.Numpy:科学计算库.提供矩阵运算的库. b.Pandas:数据分析处理库 c.scipy:数值计算库.提供数值积分和常微分方程组求解算法.提供了一个非 ...
- 常用统计分析python包开源学习代码 numpy pandas matplotlib
常用统计分析python包开源学习代码 numpy pandas matplotlib 待办 https://github.com/zmzhouXJTU/Python-Data-Analysis
- Python: NumPy, Pandas学习资料
NumPy 学习资料 书籍 NumPy Cookbook_[Idris2012] NumPy Beginner's Guide,3rd_[Idris2015] Python数据分析基础教程:NumPy ...
- python绘图:matplotlib和pandas的应用
在进行数据分析时,绘图是必不可少的模式探索方式.用Python进行数据分析时,matplotlib和pandas是最常用到的两个库.1.matplotlib库的应用准备工作如下:打开ipython,输 ...
- Numpy Pandas
数据分析 : 是把隐藏在一些看似杂乱无章的数据背后的信息提炼出来,总结出所研究对象的内在规律. 数据分析三剑客 - Numpy Pandas Matplotlib # Numpy 基于一维或多维的数 ...
- Ipython自动导入Numpy,pandas等模块
一.引言 最近在学习numpy,书上要求安装一个Ipythpn,可以自动导入Numpy,pandas等数据分析的模块,可是当我安装后,并不能自动导入numpy模块,还需要自己import.我就去查了一 ...
随机推荐
- int(a) 和 (int &) a 及 数据存储地址的探究
做题做到一个很有意思的题 void main() { float a = 1; cout << boolalpha << ((int)a == (int &)a); f ...
- linux:ssh远程调用tomcat脚本时候出错
我们都知道,使用ssh在另一台机子执行一个ssh文件的语句是酱紫的 ssh root@1.9.7.56 "chmod 777 /opt/script/tomcatStop.sh ; sh / ...
- MySQL mysql server与存储引擎
mysql server系统架构 逻辑模块组成: mysql逻辑模块可以分为两层架构,第一层是sql layer主要包括权限判断.sql解析.执行计划优化.query cache的处理等:第二层是存储 ...
- nginx配置文件详解(三)
nginx配置文件详细解析 nginx安装目录: /usr/local/nginx 配置文件: /usr/local/nginx/conf 目录下的 nginx.conf文件 nginx优化方法1 ...
- Mac下安装ipython与jupyter
IPython从Python发展而来,更倾向于科学计算.互联网数据分析更喜欢用. 首先切换root用户: sudo su - pip3自动安装ipython yuchaodeMacBook-Pro:~ ...
- Oracle创建database link(dblink)和同义词(synonym)
同一个数据库不同用户之间建立dblink和synonym 1.建立dblink 实现在A用户下通过dblink访问B用户下的数据库表,需要在A用户下创建访问B库的dblink连接 --创建远程连接db ...
- SharePoint Framework 构建你的第一个web部件(一)
博客地址:http://blog.csdn.net/FoxDave SharePoint客户端web部件是出现在SharePoint页面的控件,但却是在浏览器本地运行的.他们是SharePoint ...
- Linux可重入函数和线程安全的区别与联系(转)
*****可重入函数 函数被不同的控制流程调用,有可能在第一次调用还没返回时就再次进入该函数,这称为重入. 当程序运行到某一个函数的时候,可能因为硬件中断或者异常而使得在用户正在执行的代码暂时终端转而 ...
- 20165326 java第五周学习笔记
第五周学习笔记 ch7 内部类(&外嵌类) 内部类的类体不可以声明类变量和方法 内部类如同类的变量或方法 内部类和外嵌类在编译时生成两个class文件 匿名类 某个类的一个子类没有明显的用类声 ...
- Python 基础day4
整体大纲关于占位符 tpl = "i am %s" % "alex" tpl = "i am %s age %d" % ("a ...