实例4·股票数据分析(pygal,json格式数据处理)


import json
import requests
import pygal
import math
from itertools import groupby

# 将数据加载到一个列表中
filename = 'C://Users/Administrator/Desktop/btc_close_2017.json'
with open(filename) as f:
    texts = json.load(f)  # 1

dates = []
months = []
weeks = []
weekdays = []
close = []
# 每一天的信息
for text in texts:
    dates.append(text['date'])
    months.append(int(text['month']))
    weeks.append(int(text['week']))
    weekdays.append(text['weekday'])
    close.append(int(float(text['close'])))

# 1·收盘价折线图
line_chart = pygal.Line(x_label_rotation=20, show_minor_x_labels=False)  # x轴的标签顺时针旋转20度;不用显示全部标签
line_chart.title = '收盘价(¥)'
line_chart.x_labels = dates  # 设置x轴标签
N = 20  # x轴坐标每隔20天显示一次
line_chart.x_labels_major = dates[::N]  # ②
line_chart.add('收盘价', close)  # 交互添加
line_chart.render_to_file('收盘价折线图(¥).svg')

# 2·收盘价对数变换折线图
line_chart = pygal.Line(x_label_rotation=20, show_minor_x_labels=False)
line_chart.title = '收盘价对数变换(¥)'
line_chart.x_labels = dates
N = 20
line_chart.x_labels_major = dates[::N]
close_log = [math.log10(i) for i in close]  # 使用对数变换
line_chart.add('log收盘价', close_log)
line_chart.render_to_file('收盘价对数变换折线图(¥).svg')


# 3·月日均
def draw_line(x_data, y_data, title, y_legend):  # 传入月份列表,每日收盘数据列表
    xy_map = []
    for x, y in groupby(sorted(zip(x_data, y_data)), key=lambda m: m[0]):  # 合并传入的两数据,并按月排序;之后按照月份分为11个组
        # print(x,y)
        # 1 < itertools._grouper object at 0x00000000048ACA90 >
        # 2 < itertools._grouper object at 0x00000000048ACB00 >
        # ......
        # 11 < itertools._grouper object at 0x00000000048ACB00 >
        y_list = [v for _, v in y]
        xy_map.append([x, sum(y_list) / len(y_list)])  # 计算日平均
    x_unique, y_mean = [*zip(*xy_map)]
    line_chart = pygal.Line()
    line_chart.title = title
    line_chart.x_labels = x_unique  # 月数
    line_chart.add(y_legend, y_mean)
    line_chart.render_to_file(title + '.svg')
idx_month = dates.index('2017-12-01')  # 返回索引标号,即第334个字典,data是
line_chart_month = draw_line(months[:idx_month], close[:idx_month], '收盘价月日均值(¥)', '月日均值')

#4· 周日均
idx_week = dates.index('2017-12-11')
line_chart_week = draw_line(
    weeks[1:idx_week], close[1:idx_week], '收盘价周日均值(¥)', '周日均值')


# 5·天日均
def draw_line1(x_data, y_data, title, y_legend):
    xy_map = []
    for x, y in groupby(sorted(zip(x_data, y_data)), key=lambda m: m[0]):
        # print(x,y)
        # 1 < itertools._grouper object at 0x00000000048ACA90 >
        # 2 < itertools._grouper object at 0x00000000048ACB00 >
        # ......
        # 11 < itertools._grouper object at 0x00000000048ACB00 >
        y_list = [v for _, v in y]
        xy_map.append([x, sum(y_list) / len(y_list)])  # 计算日平均
    x_unique, y_mean = [*zip(*xy_map)]
    line_chart = pygal.Line()
    line_chart.title = title
    line_chart.x_labels = ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
    line_chart.add(y_legend, y_mean)
    line_chart.render_to_file('收盘价星期均值(¥).svg')
idx_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_line1(weekdays_int, close[1:idx_week], '收盘价星期均值(¥)', '星期均值')

# html生成
with 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))
    html_file.write('</body></html>')

结果展示
在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Python 数据分析与可视化课程设计可能包括以下内容: 1. 使用 Python 库如 NumPy、Pandas 和 Matplotlib/Seaborn 进行数据清洗、整理和分析。 2. 使用 Python 库如 Plotly、Bokeh 和 Pygal 进行数据可视化。 3. 使用 Python 库如 scikit-learn、TensorFlow 和 Keras 进行机器学习。 4. 使用 Python 库如 PySpark、Dask 和 CuPy 进行大数据分析。 5. 完成项目作业,使用所学知识对真实数据进行分析和可视化。 ### 回答2: Python数据分析与可视化课程设计涉及到对Python编程语言的基础知识、数据获取、数据清洗、数据分析和数据可视化的学习和应用。课程的设计要围绕这些内容展开,同时需要考虑到学生们的编程水平、学习目标以及实践项目的安排。 以下是一些关键内容和建议: 1. Python基础知识:首先,学生们需要掌握Python编程语言的基本语法和常用库,同时也要了解使用Python进行数据分析和可视化的必要库,如NumPy、Pandas、Matplotlib等。为了帮助初学者更好地快速入门Python,可以设计一些小练习和项目,例如编写计算器、实现芝柿图等。 2. 数据获取与清洗:数据分析与可视化的第一步是获取数据和进行数据清洗。这一部分可以介绍一些数据来源,如CSV、JSON、Excel等常见格式,还可以介绍一些Python库的使用,如requests和beautifulsoup4等,用于获取网页上的数据。同时,也要注意数据清洗的问题,如数据缺失、异常数据等。一个实践项目可以是获取并清洗用户评论数据。 3. 数据分析:在获得清洗好的数据后,就可以开始进行数据分析。这一部分可以涵盖各种常用分析方法,如描述性统计、分组统计、时间序列分析、回归分析等。可以引导学生们根据自己的兴趣选择一些实际问题进行分析,如家庭收入与教育程度的关联、某个城市的气温变化等。 4. 数据可视化:最后一步是将分析结果进行可视化。在Python中,Matplotlib和Seaborn等库都可以帮助我们进行数据可视化。这一部分可以介绍图形类型及其应用,如折线图、散点图、饼状图等。还可以讲解图形优化的方法,如添加标签、调整颜色等。一个实例项目可以是制作一个交互式的数据可视化Dash应用程序。 总之,Python数据分析与可视化课程设计应该是一个理论与实践相结合的过程。既要让学生们学会理论知识,又要帮助他们进行实际项目实践,让他们能够真正掌握此领域的技能。 ### 回答3: Python数据分析与可视化课程设计是针对数据分析领域开发的课程,旨在帮助学生掌握数据分析的基本理论和技能,能够使用Python等工具对数据进行分析和可视化。课程设计需要满足以下几个方面的要求。 首先,课程需要包含数据分析基本理论的讲解,如统计学、概率论、回归分析等。同时,需要对常见的数据分析方法进行讲解,如数据清洗、数据处理、数据挖掘等。针对不同领域的数据进行分析,需要熟练掌握数学统计、计算机编程、数据库等相关知识和工具。 其次,课程需要注重实践操作,包括数据处理和可视化。因此,需要让学生掌握Python等编程语言的基本语法和特点,能够运用Python工具完成数据分析任务。同时,需要让学生熟练掌握数据可视化图表的绘制方法,如直方图、散点图、折线图等。 第三,课程需要注重实现案例的讲解。通过实际案例的引导,能让学生深入理解数据分析方法和技能。同时,案例实现需要考虑不同领域的数据情况,涵盖医疗、金融、旅游等多个领域。 最后,课程需要加强学生的团队协作意识和能力。课程设计需要加入小组合作实践的环节,让学生相互配合完成数据分析任务,提升团队意识和沟通能力。 综上所述,Python数据分析与可视化课程设计需要注重理论与实践相结合,案例实现的教学方法,让学生熟练掌握数据分析基本方法和技能,具备团队合作实践能力的数据分析和可视化专业人才。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值