资讯专栏INFORMATION COLUMN

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

89542767 / 397人阅读

  本文关键阐述了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

相关文章

  • 数据视化 - 收藏集 - 掘金

    摘要:数据可视化的意义合理的可视化图表设计前端掘金可视化最终的目的是为了传达数据本身。是国内最优秀的前端开源产品之一,在上有超过一万五千的,在数据可视化领域已经耕耘多年作揭秘上那些开源项目的数阅读掘金声明转载请注明出处。 前端图表库 D3 入门教程 - 前端 - 掘金很早之前就听说过 D3 (Data Driven Documents)大名 ,它是一个数据驱动的可视化前端库,使用 D3 可以...

    lyning 评论0 收藏0
  • 常用的数据视化工具

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

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

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

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

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

    testbird 评论0 收藏0

发表评论

0条评论

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