我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python数据可视化

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python数据可视化

  欢迎各位阅读本篇文章,本篇文章讲述了教大家如何在from matplotlib import pyplot as plt中计划任务,编程学习网教育平台提醒各位:本篇文章纯干货~因此大家一定要认真阅读本篇文章哦

  学到了一些用Matplotlib进行数据可视化的方法。在这里整理一下。

  最开始,当然还是要导入我们需要的包:

  # -*- coding=utf-8 -*-

  from matplotlib import pyplot as plt

  from sklearn.datasets import load_iris

  import numpy as np

  import itertools1234512345

  1. 画散点图

  画散点图用plt.scatter(x,y)。画连续曲线在下一个例子中可以看到,用到了plt.plot(x,y)。

  plt.xticks(loc,label)可以自定义x轴刻度的显示,第一个参数表示的是第二个参数label显示的位置loc。

  plt.autoscale(tight=True)可以自动调整图像显示的最佳化比例 。

  plt.scatter(x,y)

  plt.title("web traffic")

  plt.xlabel("Time")

  plt.ylabel("Hits/hour")

  plt.xticks([w*7*24 for w in range(10)],['week %i' %w for w in range(10)])

  plt.autoscale(tight=True)

  plt.grid()

  ##plt.show()1234567812345678

  2. 式拟合并画出拟合曲线

  ## 多项式拟合

  fp2 = np.polyfit(x,y,3)

  f2 = np.poly1d(fp2)

  fx = np.linspace(0,x[-1],1000)

  plt.plot(fx,f2(fx),linewidth=4,color='g')

  ## f2.order: 函数的阶数

  plt.legend(["d=%i" % f2.order],loc="upper right")

  plt.show()12345678912345678

  3. 画多个子图

  这里用到的是sklearn的iris_dataset(鸢尾花数据集)。

  此数据集包含四列,分别是鸢尾花的四个特征:

  sepal length (cm)——花萼长度

  sepal width (cm)——花萼宽度

  petal length (cm)——花瓣长度

  petal width (cm)——花瓣宽度

  这里首先对数据进行一定的处理,主要就是对特征名称进行两两排列组合,然后任两个特征一个一个做x轴另一个做y轴进行画图。

  # -*- coding=utf-8 -*-

  from matplotlib import pyplot as plt

  from sklearn.datasets import load_iris

  import numpy as np

  import itertools

  data = load_iris()

  #print(data.data)

  #print(data.feature_names)

  #print(data.target)

  features = data['data']

  feature_names = data['feature_names']

  target = data['target']

  labels = data['target_names'][data['target']]

  print(data.data)

  print(data.feature_names)123456789101112131415161718123456789101112131415161718

  这里有一个排列组合参考代码,最后是取出了两两组合的情况。

Python数据可视化_大数据_数据分析_消费风险控制_编程学习网

  排列组合的结果是feature_names_2包含了排列组合的所有情况,它的每一个元素包含了一个排列组合的所有情况,比如第一个元素包含了所有单个元素排列组合的情况,第二个元素包含了所有的两两组合的情况……所以这里取出了第二个元素,也就是所有的两两组合的情况

  feature_names_2 = []

  #排列组合

  for i in range(1,len(feature_names)+1):

  iter = itertools.combinations(feature_names,i)

  feature_names_2.append(list(iter))

  print(len(feature_names_2[1]))

  for i in feature_names_2[1]:

  print(i)123456789123456789

  下面是在for循环里画多个子图的方法。对我来说,这里需要学习的有不少。比如

  for i,k in enumerate(feature_names_2[1]):这一句老是记不住。

  比如从列表中取出某元素所在的索引的方法:index1 = feature_names.index(k[0]),也即index = list.index(element)的形式。

  比如for循环中画子图的方法:plt.subplot(2,3,1+i)

  比如for循环的下面这用法:for t,marker,c in zip(range(3),”>ox”,”rgb”):

  plt.figure(1)

  for i,k in enumerate(feature_names_2[1]):

  index1 = feature_names.index(k[0])

  index2 = feature_names.index(k[1])

  plt.subplot(2,3,1+i)

  for t,marker,c in zip(range(3),">ox","rgb"):

  plt.scatter(features[target==t,index1],features[target==t,index2],marker=marker,c=c)

  plt.xlabel(k[0])

  plt.ylabel(k[1])

  plt.xticks([])

  plt.yticks([])

  plt.autoscale()

  plt.tight_layout()

  plt.show()12345678910111213141234567891011121314

  这里的可视化效果如下:

  4. 画水平线和垂直线

  比如在上面最后一幅图中,找到了一种方法可以把三种鸢尾花分出来,这是我们需要画出模型(一条直线)。这个时候怎么画呢?

  下面需要注意的就是plt.vlines(x,y_min,y_max)和plt.hlines(y,x_min,x_max)的用法。

  plt.figure(2)

  for t,marker,c in zip(range(3),">ox","rgb"):

  plt.scatter(features[target==t,3],features[target==t,2],marker=marker,c=c)

  plt.xlabel(feature_names[3])

  plt.ylabel(feature_names[2])

  tuple一开始指向的list并没有改成别的list,所以,tuple所谓的“不变”是说,tuple的每个元素,指向永远不变。即指向’a’,就不能改成指向’b’,指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的!

  理解了“指向不变”后,要创建一个内容也不变的tuple怎么做?那就必须保证tuple的每一个元素本身也不能变。

  条件判断和循环

  条件判断

  计算机之所以能做很多自动化的任务,因为它可以自己做条件判断。

  if语句

  比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,可以用if语句实现:

  age = 20

  if age >= 18:

  print 'your age is', age

  print 'adult'

  print 'END'

  注意: Python代码的缩进规则。具有相同缩进的代码被视为代码块,上面的3,4行 print 语句就构成一个代码块(但不包括第5行的print)。如果 if 语句判断为 True,就会执行这个代码块。

  缩进请严格按照Python的习惯写法:4个空格,不要使用Tab,更不要混合Tab和空格,否则很容易造成因为缩进引起的语法错误。

  注意: if 语句后接表达式,然后用:表示代码块开始。

  如果你在Python交互环境下敲代码,还要特别留意缩进,并且退出缩进需要多敲一行回车:

  >>> age = 20

  >>> if age >= 18:

  ... print 'your age is', age

  ... print 'adult'

  ...

  your age is 20

  adult

  if-else语句

  当 if 语句判断表达式的结果为 True 时,就会执行 if 包含的代码块:

  if age >= 18:

  print 'adult'

  如果我们想判断年龄在18岁以下时,打印出 ‘teenager’,怎么办?

  方法是再写一个 if:

  if age < 18:

  print 'teenager'

  或者用 not 运算:

  if not age >= 18:

  print 'teenager'

  细心的读者可以发现,这两种条件判断是“非此即彼”的,要么符合条件1,要么符合条件2,因此,完全可以用一个 if ... else ... 语句把它们统一起来:

  if age >= 18:

  print 'adult'

  else:

  print 'teenager'

  利用 if ... else ... 语句,我们可以根据条件表达式的值为 True 或者 False ,分别执行 if 代码块或者 else 代码块。

  注意: else 后面有个“:”。

  if-elif-else语句

  有的时候,一个 if ... else ... 还不够用。比如,根据年龄的划分:

  条件1:18岁或以上:adult

  条件2:6岁或以上:teenager

  条件3:6岁以下:kid

  我们可以用一个 if age >= 18 判断是否符合条件1,如果不符合,再通过一个 if 判断 age >= 6 来判断是否符合条件2,否则,执行条件3:

  if age >= 18:

  print 'adult'

  else:

  if age >= 6:

  print 'teenager'

  else:

  print 'kid'

  这样写出来,我们就得到了一个两层嵌套的 if ... else ... 语句。这个逻辑没有问题,但是,如果继续增加条件,比如3岁以下是 baby:

  if age >= 18:

  print 'adult'

  else:

else:

  if age >= 6:

  print 'teenager'

  else:

  if age >= 3:

  print 'kid'

  else:

  print 'baby'

  这种缩进只会越来越多,代码也会越来越难看。

  要避免嵌套结构的 if ... else ... ,我们可以用 if ... 多个 elif ... else ... 的结构,一次写完所有的规则:

  if age >= 18:

  print 'adult'

  elif age >= 6:

  print 'teenager'

  elif age >= 3:

  print 'kid'

  else:

  print 'baby'

  elif 意思就是 else if。这样一来,我们就写出了结构非常清晰的一系列条件判断。

  特别注意: 这一系列条件判断会从上到下依次判断,如果某个判断为 True,执行完对应的代码块,后面的条件判断就直接忽略,不再执行了。

  循环

  for循环

  list或tuple可以表示一个有序集合。如果我们想依次访问一个list中的每一个元素呢?比如 list:

  L = ['Adam', 'Lisa', 'Bart']

  print L[0]

  print L[1]

  print L[2]

  如果list只包含几个元素,这样写还行,如果list包含1万个元素,我们就不可能写1万行print。

  这时,循环就派上用场了。

  Python的 for 循环就可以依次把list或tuple的每个元素迭代出来:

  L = ['Adam', 'Lisa', 'Bart']

  for name in L:

  print name

  注意: name 这个变量是在 for 循环中定义的,意思是,依次取出list中的每一个元素,并把元素赋值给 name,然后执行for循环体(就是缩进的代码块)。

  这样一来,遍历一个list或tuple就非常容易了。

  while循环

  和 for 循环不同的另一种循环是 while 循环,while 循环不会迭代 list 或 tuple 的元素,而是根据表达式判断循环是否结束。

  比如要从 0 开始打印不大于 N 的整数:

  N = 10

  x = 0

  while x < N:

  print x

  x = x + 1

  while循环每次先判断 x < N,如果为True,则执行循环体的代码块,否则,退出循环。

  在循环体内,x = x + 1 会让 x 不断增加,最终因为 x < N 不成立而退出循环。

  如果没有这一个语句,while循环在判断 x < N 时总是为True,就会无限循环下去,变成死循环,所以要特别留意while循环的退出条件。

  break退出循环

  用 for 循环或者 while 循环时,如果要在循环体内直接退出循环,可以使用 break 语句。

  比如计算1至100的整数和,我们用while来实现:

  sum = 0

  x = 1

  while True:

  sum = sum + x

  x = x + 1

  if x > 100:

  break

  print sum

  咋一看, while True 就是一个死循环,但是在循环体内,我们还判断了 x > 100 条件成立时,用break语句退出循环,这样也可以实现循环的结束。

  continue继续循环

  在循环过程中,可以用break退出当前循环,还可以用continue跳过后续循环代码,继续下一次循环。

  假设我们已经写好了利用for循环计算平均分的代码:

  L = [75, 98, 59, 81, 66, 43, 69, 85]

  sum = 0.0

  n = 0

  for x in L:

  sum = sum + x

  n = n + 1

  print sum / n

  现在老师只想统计及格分数的平均分,就要把 x < 60 的分数剔除掉,这时,利用 continue,可以做到当 x < 60的时候,不继续执行循环体的后续代码,直接进入下一次循环:

  for x in L:

  if x < 60:

  continue

  sum = sum + x

  n = n + 1

  多重循环

  在循环内部,还可以嵌套循环,我们来看一个例子:

  for x in ['A', 'B', 'C']:

  for y in ['1', '2', '3']:

  print x + y

  x 每循环一次,y 就会循环 3 次。

  Dict类型

  我们已经知道,list 和 tuple 可以用来表示顺序集合,例如,班里同学的名字:

  ['Adam', 'Lisa', 'Bart']

  或者考试的成绩列表:

  [95, 85, 59]

  但是,要根据名字找到对应的成绩,用两个 list 表示就不方便。

  如果把名字和分数关联起来,组成类似的查找表:

  'Adam' ==> 95

  'Lisa' ==> 85

  'Bart' ==> 59

  给定一个名字,就可以直接查到分数。

  Python的 dict 就是专门干这件事的。用 dict 表示“名字”-“成绩”的查找表如下:

  d = {

d = {

  'Adam': 95,

  'Lisa': 85,

  'Bart': 59

  我们把名字称为key,对应的成绩称为value,dict就是通过 key 来查找 value。

  花括号 {} 表示这是一个dict,然后按照 key: value, 写出来即可。最后一个 key: value 的逗号可以省略。

  由于dict也是集合,len() 函数可以计算任意集合的大小:

  # plt.xticks([])

  # plt.yticks([])

  plt.autoscale()

  plt.vlines(1.6, 0, 8, colors = "c",linewidth=4,linestyles = "dashed")

  plt.hlines(2.5, 0, 2.5, colors = "y",linewidth=4,linestyles = "dashed")

  plt.show() 12345678910111234567891011

  此时可视化效果如下:

  plt.ion()打开交互模式。plt.show()不再阻塞程序运行。

  注意plt.axis()的用法。

  plt.axis([0, 100, 0, 1])

  plt.ion()

  for i in range(100):

  y = np.random.random()

  plt.autoscale()

  plt.scatter(i, y)

  plt.pause(0.01)1234567812345678

  可视化效果:

  相信最后大家阅读完毕本篇文章,肯定学到了不少知识吧?其实大家私下还得多多自学,当然如果大家还想了解更多方面的详细内容的话呢,不妨关注编程学习网教育平台,在这个学习知识的天堂中,您肯定会有意想不到的收获的!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python数据可视化

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python数据可视化

相信最后大家阅读完毕本篇文章,肯定学到了不少知识吧?其实大家私下还得多多自学,当然如果大家还想了解更多方面的详细内容的话呢,不妨关注编程学习网教育平台,在这个学习知识的天堂中,您肯定会有意想不到的收获的!
Python数据可视化
2024-04-23

python数据可视化

1、安装matplotlib在 cmd 中键入 python -m pip install matplotlib,系统将自动安装,需要等一段时间,待完成后 python -m pip list ,显示敲黑板划重点:一定通过 cdm 指定具体
2023-01-30

Python数据可视化详解

数据可视化是一种将庞杂抽象的数据转化为直观易懂的图形的数据呈现技术,它能帮助我们快速把握数据的分布和规律,更加轻松地理解和探索信息,本文通过代码图片详细介绍了Python数据可视化,感兴趣的小伙伴可以参考阅读
2023-05-16

Python数据可视化库-Matplot

我们接着上次的继续讲解,先讲一个概念,叫子图的概念。我们先看一下这段代码import matplotlib.pyplot as pltfig = plt.figure()ax1 = fig.add_subplot(3,2,1)ax2 = f
2023-01-31

Python数据可视化的方法

这篇“Python数据可视化的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python数据可视化的方法”文章吧。一、数
2023-06-30

python数据可视化怎么做

通过使用 python 库(numpy、pandas、matplotlib),可以实现数据可视化。具体步骤包括:数据准备:导入库、加载数据、处理数据。选择可视化类型:根据数据和需要传达的信息,选择合适的图表类型。创建可视化对象:使用 mat
python数据可视化怎么做
2024-05-22

Python 数据可视化神器—Pyecharts

能否在 Python 中也能用到 Echarts 的功能呢?寻找中惊喜地发现了 pyecharts,只需在python中安装该模块即可使用。

Python数据可视化举例分析

这篇文章主要介绍“Python数据可视化举例分析”,在日常操作中,相信很多人在Python数据可视化举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python数据可视化举例分析”的疑惑有所帮助!接下来
2023-06-16

Python有哪些数据可视化库

今天就跟大家聊聊有关Python有哪些数据可视化库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、Matplotlib是Python中众多数据可视化库的鼻祖,其设计风格与20世纪8
2023-06-15

Top 5 Python 数据可视化技术

掌握下面这五种高级可视化图表将使数据可视化变得容易。这些库互为补充,以最大化数据表达。

Python数据可视化库有哪些

这篇文章主要介绍“Python数据可视化库有哪些”,在日常操作中,相信很多人在Python数据可视化库有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python数据可视化库有哪些”的疑惑有所帮助!接下来
2023-06-02

编程热搜

  • Mysql分表查询海量数据和解决方案
    众所周知数据库的管理往往离不开各种的数据优化,而要想进行优化通常我们都是通过参数来完成优化的。那么到底这些参数有哪些呢?为此在本篇文章中编程学习网笔者就为大家简单介绍MySQL,以供大家参考参考,希望能帮助到大家。以上就是关于大数据的知识点了。喜欢的可以分享给你的朋友,也可以点赞噢~更多内容,就在编程学习网!
    Mysql分表查询海量数据和解决方案
  • 大数据的妙用及17年趋势
    2017年,支持大量结构化和非结构化数据的系统将继续增长。市场需要数据平台来帮助数据管理人员管理和保护大数据,同时允许最终用户进行数据分析。这些系统将逐步成熟,在企业内部的IT系统中更好地运行。所以,我们更要了解大数据!互联网普及使得网民的行为更加多元化,通过互联网产生的数据发展更加迅猛,更具代表性。互联网世界中的商品信息、社交媒体中的图片、文本信息以及视频网站的视频信息,互联网世界中的人与人交互信息、位置信息等,都已经成为大数据的最重要也是增长最快的来源。大家都了解到了吗!更多内容就在编程学习网哟
    大数据的妙用及17年趋势
  • 5G大数据时代空降来袭
    欢迎各位阅读本篇文章,本文主要讲了5G大数据时代。如今 5G 概念已不再陌生,按照行业认同的说法:2017年至2018年 5G 将在国内开始有序测试,2019年进行预商用。工信部之前已表示,中国将在2020年启动 5G 商用。编程学习网教育平台提醒各位:本篇文章纯干货~因此大家一定要认真阅读本篇文章哦!
    5G大数据时代空降来袭
  • es详解-原理-从图解构筑对es原理的初步认知
    在学习ElasticSearch原理时,我推荐你先通过官方博客中的一篇图解文章(虽然是基于2.x版本)来构筑对ES的初步认知(这种认识是体系上的快速认知)。ES详解 - 原理:从图解构筑对ES原理的初步认知前言图解ElasticSearch图解LuceneSegmentInverted IndexStored Fiel
    es详解-原理-从图解构筑对es原理的初步认知
  • elasticsearch-wrapperquery
    在工作中遇到ElasticSearch版本升级时出现Java High Level接口变更导致的兼容性问题: 之前使用的是2.4.x,考虑性能和功能的增强,需要更换为6.4.x; 2.4.x中我们使用DSL语句直接查询(数据的不确定性和方便动态建立查询规则等因素),而新的ES Java 高阶API中去掉了相关接口的支持
    elasticsearch-wrapperquery
  • 学习大数据营销思维(下)
    编程学习网: 其实,通过上面的介绍,我们知道苹果通过各类产品与服务销售相互促进以理及薄利多销的方式来盈利第二种战略联盟类型是合作方的共同赢利。苹果公司打造了一个参与方共同受益的业务系统。
    学习大数据营销思维(下)
  • 纯干货:HLS 协议详解及优化技术全面解析
    编程学习网:HLS (HTTP Live Streaming), 是由 Apple 公司实现的基于 HTTP 的媒体流传输协议。他跟 DASH 协议的原理非常类似,通过将整条流切割成一个小的可以通过 HTTP 下载的媒体文件,然后提供一个配套的媒体列表文件给客户端,让客户端顺序地拉取这些媒体文件播放, 来实现看上去是在播放一条流的效果。HLS 目前广泛地应用于点播和直播领域。
    纯干货:HLS 协议详解及优化技术全面解析
  • 关于Python 代码全面分析
    欢迎各位阅读本篇,Python(KK 英语发音:/ˈpaɪθən/)是一种面向对象、直译式计算机程序设计语言。本篇文章讲述了关于Python 代码全面分析。
    关于Python 代码全面分析
  • es详解-原理-es原理之索引文档流程详解
    ElasticSearch中最重要原理是文档的索引和文档的读取,本文带你理解ES文档的索引过程。ES详解 - 原理:ES原理之索引文档流程详解文档索引步骤顺序单个文档多个文档文档索引过程详解整体的索引流程分步骤看数据持久化过程深入ElasticSearch索引文档的实现机制写操作的关键点Lucene的写Elastics
    es详解-原理-es原理之索引文档流程详解
  • 五大“网管”必备的网络数据分析工具
    是不是在为如何分析统计网络数据和流量烦恼呢?想不想监控、运维、排障轻松一些?下面给大家提供一些免费网络分析工具,以帮助大家更好的掌控自己的网络!编程学习网教育
    五大“网管”必备的网络数据分析工具

目录