无用之学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.我就去查了一 ...
随机推荐
- 【Loadrunner基础知识】web_get_int_proterty
1.函数作用:记录http请求的响应信息 2.函数参数: HTTP_INFO_RETURN_CODE : http请求返回的状态码: HTTP_INFO_DOWNLOAD_SIZE : 返回页面下载的 ...
- 逆袭之旅DAY14.东软实训.Oracle.多表连接、分组函数、子查询
2018-07-10 08:29:55 思考应用场景 异常数据的测试 6.显示能挣得奖金的雇员的姓名.工资.奖金,并以工资和奖金降序排列.select ename,sal,commfrom empWH ...
- LY.JAVA面向对象编程.内存图
2018-07-06 一个对象的内存图 两个对象的内存图 三个对象的内存图 this static super 向上转型 向下转型
- linux 安装 DenyHosts 防止密码被暴力破解
DenyHosts DenyHosts是Python语言写的一个程序,它会分析sshd的日志文件(/var/log/secure),当发现重 复的攻击时就会记录IP到/etc/hosts.deny文件 ...
- Linux command stty
Linux command stty reference: https://blog.csdn.net/lqxandroid2012/article/details/78929506 [Purpose ...
- printf以%d形式输出浮点数的问题
若运行时从键盘上输入9876543210l,则下面程序的输出结果是 int main(){ int a;float b,c; scanf("%2d%3f%4f",&a,&a ...
- 删除Mac OS X中Finder文件打开方式列表的重复程序或失效的
清理列表, 可以在终端中输入下面提供的一行命令: /System/Library/Frameworks/CoreServices.framework/Frameworks/LaunchServices ...
- 网页设置下载apk
APK文件其实是zip格式,但后缀名被修改为apk,通过UnZip解压后,可以看到Dex文件,Dex是Dalvik VM executes的全称,即Android Dalvik执行程序,并非Ja ...
- 进程中的Manager(),实现多进程的数据共享与传递
__author__ = "Alex Li" from multiprocessing import Process, Managerimport osdef f(d, l): d ...
- Centos7防范SYN
我们这里应用的是CentOS5.3,并内核使用的是2.6.18-128.el5PAE #1 SMP .修改部分TCP ,有的是为了提高性能与负载,但是存在降低稳定性的风险.有的则是安全方面的配置,则有 ...