资讯专栏INFORMATION COLUMN

python大数据可视化制作趋势线和界限统计图表

89542767 / 640人阅读

  本文关键阐述了python大数据可视化制作趋势线和界限统计图表,python制作趋势线,呈现2个自变量的关系,当数据信息包括多个时,应用不一样颜色形状区别


  一、制作趋势线


  实现方案:


  python制作趋势线,呈现2个自变量的关系,当数据信息包括多个时,应用不一样颜色形状区别。


  实现代码:


  import numpy as np
  import pandas as pd
  import matplotlib as mpl
  import matplotlib.pyplot as plt
  import seaborn as sns
  import warnings
  warnings.filterwarnings(action='once')
  plt.style.use('seaborn-whitegrid')
  sns.set_style("whitegrid")
  print(mpl.__version__)
  print(sns.__version__)
  def draw_scatter(file):
  #Import dataset
  midwest=pd.read_csv(file)
  #Prepare Data
  #Create as many colors as there are unique midwest['category']
  categories=np.unique(midwest['category'])
  colors=[plt.cm.Set1(i/float(len(categories)-1))for i in range(len(categories))]
  #Draw Plot for Each Category
  plt.figure(figsize=(10,6),dpi=100,facecolor='w',edgecolor='k')
  for i,category in enumerate(categories):
  plt.scatter('area','poptotal',data=midwest.loc[midwest.category==category,:],s=20,c=colors<i>,label=str(category))
  #Decorations
  plt.gca().set(xlim=(0.0,0.1),ylim=(0,90000),)
  plt.xticks(fontsize=10)
  plt.yticks(fontsize=10)
  plt.xlabel('Area',fontdict={'fontsize':10})
  plt.ylabel('Population',fontdict={'fontsize':10})
  plt.title("Scatterplot of Midwest Area vs Population",fontsize=12)
  plt.legend(fontsize=10)
  plt.show()
  draw_scatter("F:数据杂坛datasetsmidwest_filter.csv")


  实现效果:

01.png

  二、绘制边界气泡图


  实现功能:


  气泡图是散点图中的一种类型,可以展现三个数值变量之间的关系,之前的文章介绍过一般的散点图都是反映两个数值型变量的关系,所以如果还想通过散点图添加第三个数值型变量的信息,一般可以使用气泡图。气泡图的实质就是通过第三个数值型变量控制每个散点的大小,点越大,代表的第三维数值越高,反之亦然。而边界气泡图则是在气泡图添加第四个类别型变量的信息,将一些重要的点选出来并连接。


  实现代码:


  import numpy as np
  import pandas as pd
  import matplotlib as mpl
  import matplotlib.pyplot as plt
  import seaborn as sns
  import warnings
  from scipy.spatial import ConvexHull
  warnings.filterwarnings(action='once')
  plt.style.use('seaborn-whitegrid')
  sns.set_style("whitegrid")
  print(mpl.__version__)
  print(sns.__version__)
  def draw_scatter(file):
  #Step 1:Prepare Data
  midwest=pd.read_csv(file)
  #As many colors as there are unique midwest['category']
  categories=np.unique(midwest['category'])
  colors=[plt.cm.Set1(i/float(len(categories)-1))for i in range(len(categories))]
  #Step 2:Draw Scatterplot with unique color for each category
  fig=plt.figure(figsize=(10,6),dpi=80,facecolor='w',edgecolor='k')
  for i,category in enumerate(categories):
  plt.scatter('area','poptotal',data=midwest.loc[midwest.category==category,:],s='dot_size',c=colors<i>,label=str(category),edgecolors='black',linewidths=.5)
  #Step 3:Encircling
  #https://stackoverflow.com/questions/44575681/how-do-i-encircle-different-data-sets-in-scatter-plot
  def encircle(x,y,ax=None,**kw):#定义encircle函数,圈出重点关注的点
  if not ax:ax=plt.gca()
  p=np.c_[x,y]
  hull=ConvexHull(p)
  poly=plt.Polygon(p[hull.vertices,:],**kw)
  ax.add_patch(poly)
  #Select data to be encircled
  midwest_encircle_data1=midwest.loc[midwest.state=='IN',:]
  encircle(midwest_encircle_data1.area,midwest_encircle_data1.poptotal,ec="pink",fc="#74C476",alpha=0.3)
  encircle(midwest_encircle_data1.area,midwest_encircle_data1.poptotal,ec="g",fc="none",linewidth=1.5)
  midwest_encircle_data6=midwest.loc[midwest.state=='WI',:]
  encircle(midwest_encircle_data6.area,midwest_encircle_data6.poptotal,ec="pink",fc="black",alpha=0.3)
  encircle(midwest_encircle_data6.area,midwest_encircle_data6.poptotal,ec="black",fc="none",linewidth=1.5,linestyle='--')
  #Step 4:Decorations
  plt.gca().set(xlim=(0.0,0.1),ylim=(0,90000),)
  plt.xticks(fontsize=12)
  plt.yticks(fontsize=12)
  plt.xlabel('Area',fontdict={'fontsize':14})
  plt.ylabel('Population',fontdict={'fontsize':14})
  plt.title("Bubble Plot with Encircling",fontsize=14)
  plt.legend(fontsize=10)
  plt.show()
  draw_scatter("F:数据杂坛datasetsmidwest_filter.csv")


  实现效果:

02.png

  综上所述,这篇文章就给大家介绍到这里了,希望可以给大家带来帮助。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/130271.html

相关文章

  • 常用的数据视化工具

    摘要:俗话说,不会使用工具来完成任务的都是进化不完全的表现,大数据时代,可视化已经深深钻进我们的生活,使用可视化工具也变的相当普遍,今天我们来总结下当下可视化工具都有哪些。是一个地图库,主要面向数据可视化用户。 俗话说,不会使用工具来完成任务的都是进化不完全的表现,大数据时代,可视化已经深深钻进我们的生活,使用可视化工具也变的相当普遍,今天我们来总结下当下可视化工具都有哪些。 showImg...

    philadelphia 评论0 收藏0
  • 小企业需要数据分析吗?

    摘要:这些功能和词汇听起来非常复杂,似乎对业务人员要求很高,但像网易有数这样的敏捷可视化分析工具不仅具备这样的能力,而且易学易用,业务人员只需简单拖拽,就能轻松制作出兼具敏捷分析与精美展示的报告。 欢迎访问网易云社区,了解更多网易技术产品运营经验。 在回答小企业是否需要数据分析这个问题之前,不妨先想想下面两个问题: 你在电脑上建过表格吗? 你基于表格中的数据画过柱形图、饼状图、折线图吗? 可...

    baishancloud 评论0 收藏0
  • 这里有8个流行的Python视化工具包,你喜欢哪个?

    摘要:下面,作者介绍了八种在中实现的可视化工具包,其中有些包还能用在其它语言中。当提到这些可视化工具时,我想到三个词探索数据分析。还可以选择样式,它模拟了像和等很流行的美化工具。有很多数据可视化的包,但没法说哪个是最好的。 showImg(https://segmentfault.com/img/remote/1460000019029121); 作者:Aaron Frederick 喜欢用...

    testbird 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<