新时代【机器学习】与【Pycharm】:【随机数据生成】与智能【股票市场分析】

目录

第一步:准备工作

1.1 安装必要的库

小李的理解:

1.2 导入库

小李的理解:

第二步:生成和准备数据

2.1 生成随机股票数据

小李的理解:

2.2 数据探索与可视化

小李的理解:

2.3 数据处理

小李的理解:

2.4 选择特征和标签

小李的理解:

第三步:拆分数据集

小李的理解:

第四步:训练决策树模型

小李的理解:

第五步:模型预测与评估

小李的理解:

结果

完整代码

总结


 

专栏:机器学习笔记

总篇:学习路线

第一卷:线性回归模型

第二卷:逻辑回归模型

第一步:准备工作

1.1 安装必要的库

小李的理解:

在开始之前,需要安装一些工具,类似于做饭前要准备好各种食材。这里,需要安装pandasscikit-learnmatplotlib,它们分别用于数据处理、机器学习和数据可视化。

在Pycharm中打开终端,并运行以下命令:

pip install pandas scikit-learn matplotlib

这些库的作用如下:

  • pandas:用于数据处理和分析,就像厨房里的切菜板和刀。
  • scikit-learn:用于机器学习模型的构建和评估,相当于厨房里的锅和炉灶。
  • matplotlib:用于数据可视化,类似于摆盘和装饰菜肴。

1.2 导入库

小李的理解:

在新的Python文件中,导入这些库。就像准备好工具后,把它们放在桌子上随时可以使用。

import pandas as pd
import numpy as np
from sklearn.model_selection import train_test_split
from sklearn.tree import DecisionTreeClassifier
from sklearn.metrics import accuracy_score
import matplotlib.pyplot as plt

第二步:生成和准备数据

2.1 生成随机股票数据

小李的理解:

现在要生成一些模拟的股票数据。想象在创建一个虚拟的股票市场,这些数据包括日期、开盘价、最高价、最低价、收盘价和成交量。就像在做一顿虚拟的大餐,需要各种食材和调料。

# 设置随机种子以确保结果可重复
np.random.seed(42)# 生成99个交易日期(工作日)
dates = pd.date_range(start='2023-01-01', periods=99, freq='B')# 随机生成股票价格数据
open_prices = np.random.uniform(low=100, high=200, size=len(dates))
high_prices = open_prices * np.random.uniform(low=1, high=1.1, size=len(dates))
low_prices = open_prices * np.random.uniform(low=0.9, high=1, size=len(dates))
close_prices = np.random.uniform(low=100, high=200, size=len(dates))
volumes = np.random.randint(low=1000, high=10000, size=len(dates))# 创建数据框
stock_data = pd.DataFrame({'日期': dates,'开盘价': open_prices,'最高价': high_prices,'最低价': low_prices,'收盘价': close_prices,'成交量': volumes
})# 将数据保存到CSV文件中
stock_data.to_csv('data.csv', index=False, encoding='utf-8-sig')
print("数据已保存到data.csv文件中")

2.2 数据探索与可视化

小李的理解:

为了更好地理解我们的数据,可以绘制收盘价的时间序列图。这就像是把做好的菜摆盘后拍张照片,看看颜色和外观怎么样。

# 绘制收盘价的时间序列图
plt.figure(figsize=(12, 6))
plt.plot(stock_data['收盘价'], label='收盘价')
plt.title('模拟股票收盘价历史')
plt.xlabel('日期')
plt.ylabel('收盘价 (美元)')
plt.legend()
plt.show()

 

这段代码将显示模拟股票收盘价随时间变化的图表。

2.3 数据处理

小李的理解:

为了进行预测,需要创建一些特征和标签。用今天的数据来预测明天的情况。具体来说,会看看今天的收盘价,并判断明天的收盘价是否会上涨。就像是根据今天的天气预测明天是否会下雨。

# 创建新的特征和标签
stock_data['次日收盘价'] = stock_data['收盘价'].shift(-1)
stock_data['价格上涨'] = (stock_data['次日收盘价'] > stock_data['收盘价']).astype(int)
stock_data.dropna(inplace=True)
print(stock_data.head())

在这段代码中:

  1. 创建了一个新的列次日收盘价,表示下一天的收盘价。
  2. 创建了标签列价格上涨,如果第二天的收盘价高于当天,则标签为1,否则为0。
  3. 删除了包含空值的行。

2.4 选择特征和标签

小李的理解:

选择一些关键数据作为特征,用它们来预测明天的情况。这些特征包括收盘价、开盘价、最高价、最低价和成交量。就像是选择了一些重要的天气指标(如温度、湿度、风速等)来预测明天的天气。

# 选择特征和标签
features = stock_data[['收盘价', '开盘价', '最高价', '最低价', '成交量']]
labels = stock_data['价格上涨']

在这段代码中,选择了特征列和标签列,用于后续的模型训练和评估。

第三步:拆分数据集

小李的理解:

为了评估模型,需要把数据分成两部分:一部分用来训练模型,另一部分用来测试模型的准确性。就像是用一些数据来训练一个预测模型,然后用其他数据来验证它的预测能力。

from sklearn.model_selection import train_test_split# 拆分数据集
X_train, X_test, y_train, y_test = train_test_split(features, labels, test_size=0.2, random_state=42)

 

在这段代码中,将数据集的80%用作训练集,20%用作测试集。还设置了random_state参数,以确保每次运行代码时拆分方式相同。

第四步:训练决策树模型

小李的理解:

可以用训练数据来训练我们的模型了。决策树是一种机器学习算法,就像是一个聪明的机器人,它可以学习数据中的模式,并根据这些模式做出预测。

from sklearn.tree import DecisionTreeClassifier# 训练决策树模型
clf = DecisionTreeClassifier()
clf.fit(X_train, y_train)

在这段代码中,首先创建了一个DecisionTreeClassifier对象,然后使用训练数据X_trainy_train来训练模型。

第五步:模型预测与评估

小李的理解:

训练完成后,可以用测试数据来评估模型的表现。让模型对测试数据做出预测,并计算预测的准确性。就像是测试一个天气预报模型,看看它预测的准确性有多高。

from sklearn.metrics import accuracy_score# 模型预测与评估
y_pred = clf.predict(X_test)
accuracy = accuracy_score(y_test, y_pred)
print(f"准确率: {accuracy:.2f}")

 

在这段代码中,我们使用clf.predict方法来预测测试数据的标签,然后使用accuracy_score函数来计算模型的准确性。

结果

 日期         开盘价         最高价         最低价         收盘价   成交量
0  2023-01-02  137.454012  138.937023  135.901969  121.582103  4440
1  2023-01-03  195.071431  195.684524  190.777431  162.289048  4766
2  2023-01-04  173.199394  184.221984  166.999404  108.534746  6644
3  2023-01-05  159.865848  164.891327  145.224374  105.168172  3914
4  2023-01-06  115.601864  121.481036  105.910136  153.135463  5968

 

日期         开盘价         最高价  ...   成交量       次日收盘价  价格上涨
0  2023-01-02  137.454012  138.937023  ...  4440  162.289048     1
1  2023-01-03  195.071431  195.684524  ...  4766  108.534746     0
2  2023-01-04  173.199394  184.221984  ...  6644  105.168172     0
3  2023-01-05  159.865848  164.891327  ...  3914  153.135463     1
4  2023-01-06  115.601864  121.481036  ...  5968  154.063512     1

 

[5 rows x 8 columns]
准确率: 0.50

完整代码

为了方便你查看和运行,以下是完整的代码:

import pandas as pd
import numpy as np
from sklearn.model_selection import train_test_split
from sklearn.tree import DecisionTreeClassifier
from sklearn.metrics import accuracy_score
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties# 设置随机种子以确保结果可重复
np.random.seed(42)# 生成99个交易日期(工作日)
dates = pd.date_range(start='2023-01-01', periods=99, freq='B')# 随机生成股票价格数据
open_prices = np.random.uniform(low=100, high=200, size=len(dates))
high_prices = open_prices * np.random.uniform(low=1, high=1.1, size=len(dates))
low_prices = open_prices * np.random.uniform(low=0.9, high=1, size=len(dates))
close_prices = np.random.uniform(low=100, high=200, size=len(dates))
volumes = np.random.randint(low=1000, high=10000, size=len(dates))# 创建数据框
stock_data = pd.DataFrame({'日期': dates,'开盘价': open_prices,'最高价': high_prices,'最低价': low_prices,'收盘价': close_prices,'成交量': volumes
})# 将数据保存到CSV文件中
stock_data.to_csv('data.csv', index=False, encoding='utf-8-sig')
print("数据已保存到data.csv文件中")# 读取CSV文件中的数据
stock_data = pd.read_csv('data.csv')
print(stock_data.head())# 设置字体属性,确保能显示中文
font = FontProperties(fname='C:/Windows/Fonts/simhei.ttf')  # 这里使用黑体,可以根据需要更改# 绘制收盘价的时间序列图
plt.figure(figsize=(12, 6))
plt.plot(stock_data['日期'], stock_data['收盘价'], label='收盘价')
plt.title('模拟股票收盘价历史', fontproperties=font)
plt.xlabel('日期', fontproperties=font)
plt.ylabel('收盘价 (美元)', fontproperties=font)
plt.legend(prop=font)
plt.xticks(rotation=45)
plt.tight_layout()
plt.show()# 创建新的特征和标签
stock_data['次日收盘价'] = stock_data['收盘价'].shift(-1)
stock_data['价格上涨'] = (stock_data['次日收盘价'] > stock_data['收盘价']).astype(int)
stock_data.dropna(inplace=True)
print(stock_data.head())# 选择特征和标签
features = stock_data[['收盘价', '开盘价', '最高价', '最低价', '成交量']]
labels = stock_data['价格上涨']# 拆分数据集
X_train, X_test, y_train, y_test = train_test_split(features, labels, test_size=0.2, random_state=42)# 训练决策树模型
clf = DecisionTreeClassifier()
clf.fit(X_train, y_train)# 模型预测与评估
y_pred = clf.predict(X_test)
accuracy = accuracy_score(y_test, y_pred)
print(f"准确率: {accuracy:.2f}")

总结

生成随机股票数据,保存为 CSV 文件,并使用决策树进行预测和评估。

  1. 安装必要的库

    使用 pip install pandas numpy scikit-learn matplotlib 安装库。
  2. 生成并保存随机数据

    生成 99 个交易日(工作日)的随机股票数据,包括日期、开盘价、最高价、最低价、收盘价和成交量。使用 pandas 将数据保存到 data.csv 文件中。
  3. 读取并准备数据

    • 从 CSV 文件中读取数据。
    • 创建新的特征(次日收盘价)和标签(价格上涨)。
  4. 数据可视化

    • 使用 matplotlib 绘制收盘价的时间序列图。
    • 设置字体属性以确保图表中能正确显示中文。
  5. 拆分数据集

    将数据集拆分为训练集和测试集。
  6. 训练决策树模型

    使用 DecisionTreeClassifier 训练模型。
  7. 模型预测与评估

    使用测试集对模型进行评估,计算模型的准确性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/371780.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

camunda最终章-springboot

1.实现并行流子流程 1.画图 2.创建实体 package com.jmj.camunda7test.subProcess.entity;import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor;import java.io.Serializable; import java.util.ArrayList; import java.util.List;Data …

golang验证Etherscan上的智能合约

文章目录 golang验证Etherscan上的智能合约为什么要验证智能合约如何使用golang去验证合约获取EtherscanAPI密钥Verify Source Code接口Check Source Code Verification Status接口演示示例及注意事项网络问题无法调用Etherscan接口(最重要的步骤) golan…

ArcGIS实战—等高线绘制

今天分享一个使用ArcGIS Pro制作等高线地图的教程,等高线是用来表达地形最常见的形式之一。那么如何制作一个效果比较好的等高线地形图呢?让我们开始今天的教程。 1 DEM数据 第一步:获取DEM地形数据,网址(https://dwt…

6、Redis系统-数据结构-05-整数

五、整数集合(Intset) 整数集合是 Redis 中 Set 对象的底层实现之一。当一个 Set 对象只包含整数值元素,并且元素数量不大时,就会使用整数集合这个数据结构作为底层实现。整数集合通过紧凑的内存布局和升级机制,实现了…

深度学习图像生成与分割模型详解:从StyleGAN到PSPNet

文章目录 Style GANDeeplab-v3FCNAdversarial AutoencodersHigh-Resolution Image Synthesis with Latent Diffusion ModelsNeRF: Representing Scenes as Neural Radiance Fields for View SynthesisPyramid Scene Parsing Network Style GAN 输入是一个潜在向量 (z)&#xff…

项目收获总结--MyBatis的知识收获

一、概述 最近几天公司项目开发上线完成,做个收获总结吧~ 今天记录MyBatis的收获和提升。 二、获取自动生成的(主)键值 insert 方法总是返回一个 int 值 ,这个值代表的是插入的行数。若表的主键id采用自增长策略,自动生成的键值在 insert…

【JSP+Servlet+Maven】——优质外卖订餐系统之概论部分

🎼个人主页:【Y小夜】 😎作者简介:一位双非学校的大二学生,编程爱好者, 专注于基础和实战分享,欢迎私信咨询! 🎆入门专栏:🎇【MySQL&#xff0…

详解基于业权一体化的统一授权中心架构设计,附材料打包

有群友问统一授权架构体系相关内容,统一授权体系隶属技术架构范畴,一般技术人员使用开源组件实现,很少在企业级层面讨论纯技术方案,但会讨论到“业权一体化”。 (一)权限管理和业权一体化的联系和区别 权…

哈喽GPT-4o,程序员如何通过GPT-4o提高工作效率

目录 一、编写代码Prompt:请用Java语言编写一个二分查找的样例 二、修正代码错误、代码优化Prompt:我们上传一张华为OD算法题的题目描述,再给它我的Java解题代码,问问它有什么问题? 三、解读代码功能、代码翻译Prompt&…

Docker——简介、安装(Ubuntu22.04)

1、简介 Docker 是一个开源的容器化平台,旨在简化应用程序的开发、交付和运行。它通过将应用程序及其所有依赖项打包到一个称为容器的标准化单元中,使应用程序能够在任何环境中一致地运行。Docker 解决了“在我的机器上能运行”的问题,使开发…

2008-2021年各省份高技术产业科研与发展(RD)活动情况数据

R&D(研究与发展)活动是推动国家和公司技术创新和经济增长的关键因素。以下是对各省份高技术产业科研与发展(R&D)活动情况数据的介绍: 数据简介 定义:R&D指在产品开发、工艺设计、生产技术改进…

MySQL的慢sql

什么是慢sql 每执行一次sql,数据库除了会返回执行结果以外,还会返回sql执行耗时,以mysql数据库为例,当我们开启了慢sql监控开关后,默认配置下,当sql的执行时间大于10s,会被记录到慢sql的日志文件…

人脸检测(Python)

目录 环境: 初始化摄像头: 初始化FaceDetector对象: 获取摄像头帧: 获取数据: 绘制数据: 显示图像: 完整代码: 环境: cvzone库:cvzone是一个基于…

RabbitMQ中常用的三种交换机【Fanout、Direct、Topic】

目录 1、引入 2、Fanout交换机 案例:利用SpringAMQP演示Fanout交换机的使用 3、Direct交换机 案例:利用SpringAMQP演示Direct交换机的使用 4、Topic交换机 案例:利用SpringAMQP演示Topic交换机的使用 1、引入 真实的生产环境都会经过e…

【论文阅读】VASA-1: Lifelike Audio-Driven Talking FacesGenerated in Real Time

整体框架。不直接生成视频帧,而是在潜在空间中生成整体面部动态和头部运动,条件是音频和其他信号。给定这些运动潜在编码,通过面部解码器生成视频帧,还接受从输入图像中提取的外观和身份特征作为输入。 构建了一个面部潜在空间并…

大连外贸建站公司wordpress主题模板

Robonaut萝卜纳特WP外贸站模板 适合用于工业机器人公司出口做外贸搭建公司官方网站使用的WordPress模板。 https://www.jianzhanpress.com/?p7091 优衣裳WordPress外贸建站模板 简洁的wordpress外贸独立站模板,适合服装、衣服、制衣外贸公司搭建公司官方网站使用…

视频翻译英文的软件有哪些?打破语言障碍就用这5个

打算趁着暑假假期悄悄努力惊艳所有人的小伙伴在哪呢~ 相信不少朋友自学都会首选在家看网课,不过有时候面对全英的外语课程,难免总会听得一头雾水~ 但其实这个问题很好解决!码好以下这5款视频翻译工具,语言障碍的问题也就都迎刃而…

打破中国算力瓶颈的暴雨模式

6月27日,一场汇聚政府领导、人工智能领域顶尖专家学者和行业领军代表的高峰论坛—“算力中国高峰论坛”在北京清华科技园紫荆会议中心盛大举行。本次论坛由庆阳市人民政府、甘肃省人工智能与算力技术重点实验室共同举办,旨在加快探索科技前沿&#xff0c…

Python 算法交易实验76 QTV200日常推进

说明 最近实在太忙, 没太有空推进这个项目,我想还是尽量抽一点点时间推进具体的工程,然后更多的还是用碎片化的时间从整体上对qtv200进行设计完善。有些结构的问题其实是需要理清的,例如: 1 要先基于原始数据进行描述…

下载linux的吐槽

本来这几天放假了,想下一个linux玩一玩 教程(我就是根据这个教程进行下载的,但是呢在进行修改BIOS 模式的 地方遇见了困难,也许是电脑修过的原因,我狂按F12 以及 FnF12都没有BIOS设置,只有一个让我选择用w…