小编会持续更新知识笔记,如果感兴趣可以三连支持。闲来无事,水文一篇,不过上手实践一下倒还是挺好玩的,这一块知识说不定以后真可以尝试拿来做数据库的报表显示。
有梦别怕苦,想赢别喊累。
目录
前言
小编我今天闲来无事,打算学习一下py,结果你猜怎么着,竟然看到py可以将数据可视化,做成报表显示,这对于一直学Java的我来说,这东西可太东西了,这要是不学一下你受得了吗?高低得学他一下啊。
这个py数据可视化也是用了第三方技术叫做Echarts,是由百度开发得一个数据可视化的框架,本来嘛使用于JS的,但是py那么火,自然他也就提供了py可用的第三方包了,但是有没有提供Java的jar包呢,这个有时间倒是可以去考察一下。
JSON数据格式的转换
这个东西既然扯到数据了,JSON是逃不掉的,虽然我知道这玩意大家很熟了,但是我还是得水一下文章的。JSON是一种轻量级得数据交互格式。可以按照JSON指定得格式去组织和封装数据。本质上就是一个带有特定格式的字符串。JSON主要就是一种在各个编程语言中流通的数据格式,负责不同编程语言中的数据传递和交互。类似于国际通用语言英语,中国通用语言普通话。
具体格式就像上面这样,其实就和py中定义字典或者列表内部嵌套字典差不多,键:值,不同键用逗号隔开。所以在py中去实现Python数据和Json数据的相互转换倒是很方便,我们只要导入对应的json模块,然后使用里面提供好的方法就好了。
下面我们就来演示一下json模块的使用吧,因为存在中文的编码问题,所以我们还需要传入一个关键参数ensure_ascii=False。
import json
data = [{"name": "张大山", "age": 11}, {"name": "王大锤", "age": 13}, {"name": "赵小虎", "age": 16}]
# python 转 json
json_str = json.dumps(data, ensure_ascii=False)
print(type(json_str))
print(json_str)
# json 转 python
s = '[{"name":"张大山","age":11},{"name":"王大锤","age":13},{"name":"赵小虎","age":16}]'
l = json.loads(s)
print(type(l))
print(l)
以上就是py实现JSON数据格式互相转换,主意好列表和字典的格式后就dumps和loads两个方法。
pyecharts简介和入门使用
通过前面我们也知道了pyecharts就是一款第三方可视化数据框架,下面这个就是pyecharts的官网
渲染图表 - pyecharts - A Python Echarts Plotting Library built with love.https://05x-docs.pyecharts.org/#/zh-cn/prepare 官网其实还是挺好玩的,有好多报表图模型,想用哪个就可以参考它的代码,然后照葫芦画瓢就可以实现出来。下面这个是pyecharts的一个画廊网址也是挺不错的。
中文简介 - Document (pyecharts.org)https://gallery.pyecharts.org/#/README 至于怎么安装pycharts,其实分为两种方式,第一种就是我们可以通过命令行来安装。如果你写代码用的是第二种就是通过pyCharm来安装。
第一种我们win加r输入cmd打开命令行窗口,接着输入下面这行命令直接回车等待下载完成就好了。
pip install pyecharts
接着检验是否安装好了,我们可以通过输入python,然后尝试import pyecharts导入一下,如果没有问题,就证明导入成功了。
第二种方法就是我们可以通过右下角的设置里的解释器设置中的添加解释器搜索pyecharts进行安装就好了。
接着我们来看看pyecharts如何使用,其实这一块呢也是非常简单,我们只需要照着官网的模板照葫芦画瓢就好了 ,我们就来做一个折线图图像吧。这一块我们首先就是要导入Line这个类,顾名思义就是来画线的。这里我们用到了两个方法,一个是add_xaxis()用来标明x轴的数据项有哪些,add_yaxis()用来标明y轴数据项表示的内容和数据值。这一块第一个数据项不能省略,因为你总不能y轴都不表示什么含义吧,接着我们就可以调用render方法就可以将代码生成图像。
# 导包
from pyecharts.charts import Line
# 创建一个折线图对象
line = Line()
# 给折线图对象添加x轴的数据
line.add_xaxis(["中国","美国","英国"])
# 给折线图对象添加y轴的数据
line.add_yaxis("GDP",[30,20,10])
# 通过render方法,将代码生成为图像
line.render()
接着我们右键运行,就可以看到我们当前目录下多了一个叫render.html的文件,相信你也知道这是一个前端界面文件,感兴趣的可以打开看看,我们直接用浏览器打开就会得到我们上面绘制的折线图了。
其实上面这个图片看着还是有点单调的,我们还可以给他添点和数据无关的东西,比如标题,工具箱, 鼠标移动效果等。这些叫做全局配置选项,而上面我们配置的叫做系列配置选项。配置全局配置选项其实也很简单,照着官网找到我们想要的直接CV就好了。
# 设置全局配置项
line.set_global_opts(
# 设置标题内容以及位置
title_opts=TitleOpts(title="GDP展示", pos_left="center", pos_bottom="1%"),
# 设置图例是否显示
legend_opts=LegendOpts(is_show=True),
# 设置工具箱是否显示
toolbox_opts=ToolboxOpts(is_show=True),
# 设置视觉映射是否显示
visualmap_opts=VisualMapOpts(is_show=True),
)
# 通过render方法,将代码生成为图像
line.render()
这里我是配置好了标题,图例,工具箱和鼠标移动效果,当然你还可以配置些别的,这里只是演示用法。记住我们要把render()方法放在最后,不然就设置不成功了。
这里我把鼠标放在上面确实有了显示,下方也多了一个标题,右上角也多了一个工具箱,工具箱支持很多功能例如保存图片,切换柱状图,展示数据等等,功能还是非常丰富的。
到这里我们pyecharts的入门使用就到此为止了,是不是特别简单,我们只需要把官网的模板拿过来照葫芦画瓢就好了。
这东西上手还是挺简单的,只要可以拿到JSON数据,然后照葫芦画瓢就好了,业务在于如何拿到JSON数据然后转换,绘制可视化图形就是美工了。
带着决心起床,带着满意入睡。