制作交易收盘价走势图:JSON格式

2023-10-28 11:30

本文主要是介绍制作交易收盘价走势图:JSON格式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JSON格式

JSON格式的文件使用json模块来处理。
下面看一个JSON文件里面的内容是什么样子的:
在这里插入图片描述
就是一个很长的Python列表,其中每个元素都是一个包含五个键的字典:统计日期,月份,周数,周几以及收盘价。

下载收盘数据

from __future__ import (absolute_import, division, print_function,unicode_literals)
try:# Python 2.x 版本from urllib2 import urlopen
except ImportError:# Python 3.x 版本from urllib.request import urlopen  # 1
import json
import requests
import pygal
import math
from itertools import groupbyjson_url = 'https://raw.githubusercontent.com/muxuezi/btc/master/btc_close_2017.json'
response = urlopen(json_url)  # 2
# 读取数据
req = response.read()
# 将数据写入文件
with open('btc_close_2017_urllib.json', 'wb') as f:  # 3f.write(req)
# 加载json格式
file_urllib = json.loads(req.decode('utf8'))  # 4
print(file_urllib)json_url = 'https://raw.githubusercontent.com/muxuezi/btc/master/btc_close_2017.json'
req = requests.get(json_url)  # 1
# 将数据写入文件
with open('btc_close_2017_request.json', 'w') as f:f.write(req.text)  # 2
file_requests = req.json()  # 3print(file_urllib == file_requests)

提取相关的数据

下面编写一个小程序来提取btc_close_2017.json文件中的相关信息:

import json#将数据加载到一个列表中
filename='btc_close_2017.json'
with open(filename) as f:btc_data=json.load(f)#打印每一天的信息
for btc_dict in btc_data:date=btc_dict['date']month=btc_dict['month']week=btc_dict['week']weekday=btc_dict['weekday']close=btc_dict['close']print("{} is month{}week{},{},the close price is {}RMB".format(date,month,week,weekday,close))

在这里插入图片描述

import json#将数据加载到一个列表中
filename='btc_close_2017.json'
with open(filename) as f:btc_data=json.load(f)#打印每一天的信息
for btc_dict in btc_data:date=btc_dict['date']month=int(btc_dict['month'])week=int(btc_dict['week'])weekday=btc_dict['weekday']close=int(btc_dict['close'])print("{} is month{}week{},{},the close price is {}RMB".format(date,month,week,weekday,close))

我们运行来试试,看看结果如何
在这里插入图片描述
没想到出现了异常错误,在实际工作中,原始数据的格式经常不是统一的,此类数值类型转换造成的ValueError异常十分普遍,这里的原因在于,Python不能直接将包含小数点的字符串‘6928.6492’转换为整数。为了消除这种错误,需要先将字符串转换为浮点数(float),再将浮点数转换为整数(int):

import json#将数据加载到一个列表中
filename='btc_close_2017.json'
with open(filename) as f:btc_data=json.load(f)#打印每一天的信息
for btc_dict in btc_data:date=btc_dict['date']month=int(btc_dict['month'])week=int(btc_dict['week'])weekday=btc_dict['weekday']close=int(float(btc_dict['close']))print("{} is month{}week{},{},the close price is {}RMB".format(date,month,week,weekday,close))

在这里插入图片描述
好了,解决了。

绘制收盘价折线图

之前了解过了pygal绘制条形图(bar chart)和matplotlib绘制折线图(line chart),下面用Pygal来实现收盘价的折线图

import json
import pygal#将数据加载到一个列表中
filename='btc_close_2017.json'
with open(filename) as f:btc_data=json.load(f)#创建5个列表,分别存储日期和收盘价
dates=[]
months=[]
weeks=[]
weekdays=[]
close=[]#打印每一天的信息
for btc_dict in btc_data:dates.append(btc_dict['date'])months.append(int(btc_dict['month']))weeks.append(int(btc_dict['week']))weekdays.append(btc_dict['weekday'])close.append(int(float(btc_dict['close'])))#print("{} is month{}week{},{},the close price is {}RMB".format(date,month,week,weekday,close))line_chart=pygal.Line(x_label_rotation=20,show_minor_x_labels=False)
line_chart.title='收盘价(RMB)'
line_chart.x_labels=dates
N=20 #x轴坐标每隔20天显示一次
line_chart.add('收盘价',close)
line_chart.render_to_file('收盘价折线图.svg')

运行后,会在文件保存的目录下面生成一个.svg文件
在这里插入图片描述
然后用浏览器打开如下图:

在这里插入图片描述

时间序列特征初探

进行时间序列分析总是期望发现趋势(trend)、周期性(seasonality)和噪声(noise),从而能够描述事实、预测未来、做出决策。对数变换(log transformation)是可以将波动中非线性的趋势消除。Python标准库的数学模块math来解决,我i们用以10为底的对数函数math.log10计算收盘价,日期仍然保持不变,这种方式称为半对数变换(semi-logarithmic)。

import json
import pygal
import math#将数据加载到一个列表中
filename='btc_close_2017.json'
with open(filename) as f:btc_data=json.load(f)#创建5个列表,分别存储日期和收盘价
dates=[]
months=[]
weeks=[]
weekdays=[]
close=[]#打印每一天的信息
for btc_dict in btc_data:dates.append(btc_dict['date'])months.append(int(btc_dict['month']))weeks.append(int(btc_dict['week']))weekdays.append(btc_dict['weekday'])close.append(int(float(btc_dict['close'])))#print("{} is month{}week{},{},the close price is {}RMB".format(date,month,week,weekday,close))line_chart=pygal.Line(x_label_rotation=20,show_minor_x_labels=False)
line_chart.title='收盘价对数变换(RMB)'
line_chart.x_labels=dates
N=20 #x轴坐标每隔20天显示一次
line_chart.x_labels_major=dates[::N]
close_log=[math.log10(_)for _ in close]
line_chart.add('log收盘价',close_log)
line_chart.render_to_file('收盘价折线图.svg')

在这里插入图片描述
现在用对数变换剔除非线性趋势之后,整体上涨的趋势更接近线性增长,并且从图中可以看出每个季度末似乎有显著的周期性—3月、6月、9月都出现了波动,那么,按照这样的推算12月是不是也会出现这样的波动呢?下面看看收盘的月日均值和周日均值的表现。

收盘价均值

import json
import pygal
import math
from itertools import groupby#将数据加载到一个列表中
filename='btc_close_2017.json'
with open(filename) as f:btc_data=json.load(f)#创建5个列表,分别存储日期和收盘价
dates=[]
months=[]
weeks=[]
weekdays=[]
close=[]#打印每一天的信息
for btc_dict in btc_data:dates.append(btc_dict['date'])months.append(int(btc_dict['month']))weeks.append(int(btc_dict['week']))weekdays.append(btc_dict['weekday'])close.append(int(float(btc_dict['close'])))#print("{} is month{}week{},{},the close price is {}RMB".format(date,month,week,weekday,close))line_chart = pygal.Line(x_label_rotation=20, show_minor_x_labels=False)  # ①
line_chart.title = '收盘价(¥)'
line_chart.x_labels = dates
N = 20  # x轴坐标每隔20天显示一次
line_chart.x_labels_major = dates[::N]  # ②
line_chart.add('收盘价', close)
line_chart.render_to_file('收盘价折线图(¥).svg')line_chart = pygal.Line(x_label_rotation=20, show_minor_x_labels=False)
line_chart.title = '收盘价对数变换(¥)'
line_chart.x_labels = dates
N = 20  # x轴坐标每隔20天显示一次
line_chart.x_labels_major = dates[::N]
close_log = [math.log10(_) for _ in close]  # ①
line_chart.add('log收盘价', close_log)
line_chart.render_to_file('收盘价对数变换折线图(¥).svg')
line_chartdef draw_line(x_data, y_data, title, y_legend):xy_map = []for x, y in groupby(sorted(zip(x_data, y_data)), key=lambda _: _[0]):  # 2y_list = [v for _, v in y]xy_map.append([x, sum(y_list) / len(y_list)])  # 3x_unique, y_mean = [*zip(*xy_map)]  # 4line_chart = pygal.Line()line_chart.title = title#line_chart.x_labels = x_uniquex_unique_str=int_str(x_unique)line_chart.x_labels = x_unique_strline_chart.add(y_legend, y_mean)line_chart.render_to_file(title + '.svg')return line_chartdef int_str(list_0):list_1=[]for x in list_0:x_str=str(x)list_1.append(x_str)return list_1idx_month = dates.index('2017-12-01')
line_chart_month = draw_line(months[:idx_month], close[:idx_month], '收盘价月日均值(¥)', '月日均值')
line_chart_monthidx_week = dates.index('2017-12-11')
line_chart_week = draw_line(weeks[1:idx_week], close[1:idx_week], '收盘价周日均值(¥)', '周日均值')
line_chart_weekidx_week = dates.index('2017-12-11')
wd = ['Monday', 'Tuesday', 'Wednesday','Thursday', 'Friday', 'Saturday', 'Sunday']
weekdays_int = [wd.index(w) + 1 for w in weekdays[1:idx_week]]
line_chart_weekday = draw_line(weekdays_int, close[1:idx_week], '收盘价星期均值(¥)', '星期均值')
line_chart_weekday.x_labels = ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
line_chart_weekday.render_to_file('收盘价星期均值(¥).svg')
line_chart_weekdaywith open('收盘价Dashboard.html', 'w', encoding='utf8') as html_file:html_file.write('<html><head><title>收盘价Dashboard</title><meta charset="utf-8"></head><body>\n')for svg in ['收盘价折线图(¥).svg', '收盘价对数变换折线图(¥).svg', '收盘价月日均值(¥).svg','收盘价周日均值(¥).svg', '收盘价星期均值(¥).svg']:html_file.write('    <object type="image/svg+xml" data="{0}" height=500></object>\n'.format(svg))  # 1html_file.write('</body></html>')

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

再写上面的代码时,出现了一个错误,如下,总是提示
在这里插入图片描述
是x轴的数据有问题,x轴应该修改为数值型str,修改方式如下:
在这里插入图片描述

这篇关于制作交易收盘价走势图:JSON格式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/292912

相关文章

Linux镜像文件制作方式

《Linux镜像文件制作方式》本文介绍了Linux镜像文件制作的过程,包括确定磁盘空间布局、制作空白镜像文件、分区与格式化、复制引导分区和其他分区... 目录1.确定磁盘空间布局2.制作空白镜像文件3.分区与格式化1) 分区2) 格式化4.复制引导分区5.复制其它分区1) 挂载2) 复制bootfs分区3)

C#中DateTime的格式符的实现示例

《C#中DateTime的格式符的实现示例》本文介绍了C#中DateTime格式符的使用方法,分为预定义格式和自定义格式两类,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录DateTime的格式符1.核心概念2.预定义格式(快捷方案,直接复用)3.自定义格式(灵活可控

使用C#导出Excel数据并保存多种格式的完整示例

《使用C#导出Excel数据并保存多种格式的完整示例》在现代企业信息化管理中,Excel已经成为最常用的数据存储和分析工具,从员工信息表、销售数据报表到财务分析表,几乎所有部门都离不开Excel,本文... 目录引言1. 安装 Spire.XLS2. 创建工作簿和填充数据3. 保存为不同格式4. 效果展示5

MySQL 中的 JSON_CONTAIN用法示例详解

《MySQL中的JSON_CONTAIN用法示例详解》JSON_CONTAINS函数用于检查一个JSON文档中是否包含另一个JSON文档,这篇文章给大家介绍JSON_CONTAINS的用法、语法、... 目录深入了解 mysql 中的 jsON_CONTAINS1. JSON_CONTAINS 函数的概述2

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

使用python制作一款文件粉碎工具

《使用python制作一款文件粉碎工具》这篇文章主要为大家详细介绍了如何使用python制作一款文件粉碎工具,能够有效粉碎密码文件和机密Excel表格等,感兴趣的小伙伴可以了解一下... 文件粉碎工具:适用于粉碎密码文件和机密的escel表格等等,主要作用就是防止 别人用数据恢复大师把你刚删除的机密的文件恢

Vue3 如何通过json配置生成查询表单

《Vue3如何通过json配置生成查询表单》本文给大家介绍Vue3如何通过json配置生成查询表单,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录功能实现背景项目代码案例功能实现背景通过vue3实现后台管理项目一定含有表格功能,通常离不开表单

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结