我用python帮朋友做了张图,结果

Aidan075
• 阅读 1319

↖一个宝藏公众号,长的好看的人都关注了

我用python帮朋友做了张图,结果

却发现他是这么拿我当兄弟的

事情的经过是这样的:

我开开心心的去一家烧饼店吃饭

我用python帮朋友做了张图,结果

抬头一看,二师兄又涨价了

叹了口气,再这么下去真的要吃不起夹肉的烧饼了

点了两个烧饼一碗馄饨

快吃完的时候,收到了朋友阿东的微信

阿东是我初中同学,好些日子没联系了

我用python帮朋友做了张图,结果

眼瞅着他快聊到区块链了,虽然这事不靠谱,但还是答应了阿东帮他做图。

我赶紧吃完最后一口,回公司,决定不午睡了。

开工!

阿东想要这样的图:

我用python帮朋友做了张图,结果

折线图嘛,先获取数据吧

正好图片中显示了数据来源:“中国养猪网”

打开官网,找到并跳转到猪价网址 http://zhujia.zhuwang.cc/

我用python帮朋友做了张图,结果

F12,Network查看异步请求XHR,成功找到价格接口。

我用python帮朋友做了张图,结果

新标签页打开,在线解析Json数据,不了解这块知识的朋友可以点击 在python里玩转Json数据

我用python帮朋友做了张图,结果

部分爬虫代码(完整代码见文末下载地址):

def get_comments(url):  
    doc = get_json(url)  
    dic = {}  
    dic['pigprice'] = doc['pigprice']  
    dic['pig_in'] = doc['pig_in']  
    dic['pig_local'] = doc['pig_local']  
    dic['maizeprice'] = doc['maizeprice']  
    dic['bean'] = doc['bean']  
    a = '-'.join(doc['time'][3])  
    b = time.strftime('%Y-%m-%d',time.localtime(time.time()))  
    print(dateRange(a,b))  
    dic['time'] = dateRange(a,b)  
    return pd.DataFrame(dic)  

data =get_comments('http://zhujia.zhuwang.cc/index/api/chartData?areaId=-1&aa=1571997555296')

运行结果:

我用python帮朋友做了张图,结果

成功获取最近一年的各种价格√

下面开始给阿东做折线图:

生猪价格的话选第一个外三元就好了,

使用 matplotlib 轻松可以做出折线图。

from pylab import mpl  
import  matplotlib.pyplot as plt  
mpl.rcParams['font.sans-serif'] = ['SimHei'] # 指定默认字体  
mpl.rcParams['axes.unicode_minus']  

plt.figure(figsize=(8,4), dpi=80)  
plt.plot(data['time'],data['pigprice'], color="r",linestyle = "-")  
plt.xticks(data['time'][2::121], rotation=0)  
plt.xlabel("生猪(外三元) 元/公斤")

我用python帮朋友做了张图,结果

感觉还差点东西,可以标注一下最新一天的价格

另外既然已经获取了玉米和豆粕的价格,就一起做了吧~

利用 plt.subplot 可以绘制多个子图

from pylab import mpl  
import  matplotlib.pyplot as plt  
mpl.rcParams['font.sans-serif'] = ['SimHei'] # 指定默认字体  
mpl.rcParams['axes.unicode_minus']  

plt.figure(figsize=(8,10), dpi=80)  
plt.figure(1)  
ax1 = plt.subplot(311)  
plt.plot(data['time'],data['pigprice'], color="r",linestyle = "-")  
plt.xticks([])  
plt.annotate(data['pigprice'][365], xy=(data['time'][365], 40), xytext=(data['time'][270], 35), arrowprops=dict(facecolor='black', shrink=0.1, width=0.5))  
plt.xlabel("生猪(外三元) 元/公斤")  

ax2 = plt.subplot(312)  
plt.plot(data['time'],data['maizeprice'],color="y",linestyle = "-")  
plt.xticks([])  
plt.xlabel("玉米(15%水分) 元/吨")  

ax3 = plt.subplot(313)  
plt.plot(data['time'],data['bean'],color="g",linestyle = "-")  
plt.xlabel("豆粕(43%蛋白) 元/吨")  
plt.xticks(data['time'][2::121], rotation=0)

我用python帮朋友做了张图,结果

完工,

发给阿东。

却得到这样的回复

我用python帮朋友做了张图,结果

我用python帮朋友做了张图,结果

原来在他心里是这么定义朋友的啊。

可以,

这很东哥,

这很兄弟。

本文半虚构,如有雷同,那还真是巧了。

作者:朱小五,互联网公司数据分析师,热衷于爬虫,数据分析,可视化,个人公众号《凹凸玩数据》,在沙雕的同时居然还能学到技术。

一键爬取最新猪价&可视化的代码已上传github:

https://github.com/zpw1995/aotodata/tree/master/interest/pig

本文转转自微信公众号凹凸数据原创https://mp.weixin.qq.com/s/CGoSAWNDght23RR0CbLfGQ,可扫描二维码进行关注: 我用python帮朋友做了张图,结果 如有侵权,请联系删除。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Aidan075 Aidan075
3年前
我用python帮朋友做了张图,结果
↖一个宝藏公众号,长的好看的人都关注了却发现他是这么拿我当兄弟的事情的经过是这样的:我开开心心的去一家烧饼店吃饭(ht
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
4cast
4castpackageloadcsv.KumarAwanish发布:2020122117:43:04.501348作者:KumarAwanish作者邮箱:awanish00@gmail.com首页:
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这