【大麦小米学量化】将list写入csv并读取还原为list(自选股操作)

2023-12-16 11:12

本文主要是介绍【大麦小米学量化】将list写入csv并读取还原为list(自选股操作),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、将list写入csv并读取还原为list(含源代码)
  • 二、进阶应用(自选股信息交换)
  • 总结


前言

有时候我们需要将list写入本地文件,作为交换信息由其它程序进行读取。就比如,做量化交易的时候,一个程序进行选股,一个程序读取选股信息后进行交易。当然也可以写入redis等,方法很多。但写入本地csv文件最简单,毕竟自选股的结果就是一个list就够了。

下面进入正文。

一、将list写入csv并读取还原为list(含源代码)

在网上找了好些个方法,最终修改为如下代码,这里做个分享,方便后来人。
这里踩的坑主要有:
1、list可以写入csv,但是每一个元素的字符都被逗号分割后存储,还原出来很麻烦;
2、list的每个元素写入csv后,都会有一个空行,在还原的时候多出来一个空的元素;

经过修改和完善,目前已经可以完全实现list写入csv并原样还原。为方便调用,将其包装为两个函数。具体代码如下:

import csvdef list2csv(data,filename='output.csv'):# 打开或创建CSV文件并指定写入模式, newline=''则不生成空行with open(filename, mode='w', newline='') as file:# 初始化CSV writer对象writer = csv.writer(file)# 遍历数据列表,逐行写入到CSV文件中for item in data:writer.writerows([item])print("已成功将列表写入CSV文件!")def csv2list(filename):ret_list = []# 打开CSV文件进行读取操作with open(filename) as f:f_reader = csv.reader(f)#循环文件中的每一行for row in f_reader:# print(row)ret_list.append(''.join(row)) print("成功从CSV文件中读取数据并转换为列表形式。")return ret_listif __name__ == "__main__": data = ['300750','300150','600450','601068.SH']list2csv(data)ret = csv2list(filename='output.csv')print(ret)
已成功将列表写入CSV文件!
成功从CSV文件中读取数据并转换为列表形式。
['300750', '300150', '600450', '601068.SH']
请按任意键继续. . .

二、进阶应用(自选股信息交换)

比如我们通过pywencai完成选股(【大麦小米学量化】通过pywencai访问同花顺问财接口实现智能选股),并将股票代码写入一个固定路径和文件名的csv文件,后边再进行读取还原。具体代码如下:

if __name__ == "__main__": import pywencaiquery_str = '非停盘;非ST;连涨3天涨幅1%-4%;均线多头排列;无长上影线'# 根据需要自行修改,此处仅做演示,不做交易参考。df = pywencai.get(query=query_str, sort_key='股票代码', sort_order='asc', perpage=10 )print(df)code_list = df['股票代码'].values.tolist()print(code_list)list2csv(code_list,filename='mystock.csv')mystock = csv2list(filename='mystock.csv')print(mystock)

运行结果如下:可以看到还原成list与原始信息一模一样。

        股票代码  股票简称    最新价 交易状态[20231215]  ... 最低价:前复权[20231215] 收盘价:前复权[20231213] market_code    code
0  000782.SZ  美达股份   5.83             交易  ...              5.74              5.65          33  000782
1  831304.BJ  迪尔化工   7.19             交易  ...              6.74              6.46         151  831304
2  831834.BJ  三维股份   7.43             交易  ...              7.09              7.08         151  831834
3  832225.BJ  利通科技  17.62             交易  ...             17.10             17.27         151  832225
4  832419.BJ  路斯股份  10.97             交易  ...             10.64             10.36         151  832419
5  832522.BJ  纳科诺尔  20.96             交易  ...             20.24             20.33         151  832522
6  833580.BJ  科创新材   7.43             交易  ...              7.20              7.05         151  833580
7  834415.BJ  恒拓开源   6.38             交易  ...              6.13              6.14         151  834415
8  834639.BJ  晨光电缆   5.36             交易  ...              5.13              5.09         151  834639
9  836260.BJ  中寰股份   8.41             交易  ...              8.12              8.07         151  836260[10 rows x 23 columns]
['000782.SZ', '831304.BJ', '831834.BJ', '832225.BJ', '832419.BJ', '832522.BJ', '833580.BJ', '834415.BJ', '834639.BJ', '836260.BJ']
已成功将列表写入CSV文件!
成功从CSV文件中读取数据并转换为列表形式。
['000782.SZ', '831304.BJ', '831834.BJ', '832225.BJ', '832419.BJ', '832522.BJ', '833580.BJ', '834415.BJ', '834639.BJ', '836260.BJ']
请按任意键继续. . .

总结

为了快速实现信息交换,博主尝试了很多方法,这个方法既简单,需要的代码也最少。极容易上手也不容易出错。

如果有人说我要保存成dict,可以移步到博主TOML的文章。
【TOML配置文件】配置文件我用TOML!人性化,少出错!

这篇关于【大麦小米学量化】将list写入csv并读取还原为list(自选股操作)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

java Stream操作转换方法

《javaStream操作转换方法》文章总结了Java8中流(Stream)API的多种常用方法,包括创建流、过滤、遍历、分组、排序、去重、查找、匹配、转换、归约、打印日志、最大最小值、统计、连接、... 目录流创建1、list 转 map2、filter()过滤3、foreach遍历4、groupingB

Java操作PDF文件实现签订电子合同详细教程

《Java操作PDF文件实现签订电子合同详细教程》:本文主要介绍如何在PDF中加入电子签章与电子签名的过程,包括编写Word文件、生成PDF、为PDF格式做表单、为表单赋值、生成文档以及上传到OB... 目录前言:先看效果:1.编写word文件1.2然后生成PDF格式进行保存1.3我这里是将文件保存到本地后

使用Python处理CSV和Excel文件的操作方法

《使用Python处理CSV和Excel文件的操作方法》在数据分析、自动化和日常开发中,CSV和Excel文件是非常常见的数据存储格式,ython提供了强大的工具来读取、编辑和保存这两种文件,满足从基... 目录1. CSV 文件概述和处理方法1.1 CSV 文件格式的基本介绍1.2 使用 python 内

Python使用Colorama库美化终端输出的操作示例

《Python使用Colorama库美化终端输出的操作示例》在开发命令行工具或调试程序时,我们可能会希望通过颜色来区分重要信息,比如警告、错误、提示等,而Colorama是一个简单易用的Python库... 目录python Colorama 库详解:终端输出美化的神器1. Colorama 是什么?2.