VeighNa量化社区
你的开源社区量化交易平台
Member
avatar
加入于:
帖子: 22
声望: 0

p2209-C-7900 p2209-C-7900 494.0 2022-07-20 21:15:15.500000+08:00
p2209-C-8000 p2209-C-8000 390.5 2022-07-20 21:15:15.500000+08:00
p2209-C-8100 p2209-C-8100 336.0 2022-07-20 21:15:15.500000+08:00
p2209-C-8200 p2209-C-8200 296.0 2022-07-20 21:15:15.500000+08:00
p2209-C-8300 p2209-C-8300 244.5 2022-07-20 21:15:15.500000+08:00
p2209-C-8400 p2209-C-8400 207.0 2022-07-20 21:15:15.500000+08:00
m2209-P-3550 m2209-P-3550 27.0 2022-07-20 21:15:15.500000+08:00
苯乙烯2207 eb2207 9900.0 2022-07-20 21:15:15.600000+08:00
Exception in thread Thread-1 (_run):
Traceback (most recent call last):
File "C:\veighna_studio\lib\threading.py", line 1009, in _bootstrap_inner
File "C:\veighna_studio\lib\threading.py", line 946, in run
File "C:\veighna_studio\lib\site-packages\vnpy\event\engine.py", line 60, in _run
File "C:\veighna_studio\lib\site-packages\vnpy\event\engine.py", line 73, in _process
File "C:\veighna_studio\lib\site-packages\vnpy\event\engine.py", line 73, in <listcomp>
File "c:\Users\Hasee\Desktop\vnpyFile\实践3\write_csv.py", line 125, in process_contract_event
OSError: [Errno 24] Too many open files: 'C:\Users\Hasee\20220720\MA306.csv'

Member
avatar
加入于:
帖子: 4703
声望: 287

不知道你的具体操作了,如果是linux系统限制的问题,可以自己修改系统限制

Member
avatar
加入于:
帖子: 22
声望: 0

我用的是win11 运行

加载内置模块

from time import sleep
from csv import DictWriter
from typing import Dict, TextIO
from datetime import datetime

加载三方模块

from vnpy.event import Event, EventEngine
from vnpy.trader.engine import MainEngine
from vnpy.trader.event import EVENT_TICK, EVENT_CONTRACT
from vnpy.trader.object import TickData, ContractData, SubscribeRequest
from vnpy.trader.utility import load_json, TRADER_DIR
from vnpy_ctp import CtpGateway

全局变量

main_engine: MainEngine = None
symbol_file_map: Dict[str, TextIO] = {}
symbol_writer_map: Dict[str, DictWriter] = {}

today = datetime.now().strftime("%Y%m%d")
csv_dir = TRADER_DIR.joinpath(today)
if not csv_dir.exists():
csv_dir.mkdir()

def run():
"""程序主入口"""

# 创建事件引擎
event_engine = EventEngine()

# 注册事件监听
event_engine.register(EVENT_CONTRACT, process_contract_event)
event_engine.register(EVENT_TICK, process_tick_event)

# 初始化全局对象
global main_engine
main_engine = MainEngine(event_engine)

# 添加并连接交易接口
main_engine.add_gateway(CtpGateway)

# 对于普通用户直接在这里写接口配置即可
setting = {
    "用户名": "71",
    "密码": "!",
    "经纪商代码": "0",
    "交易服务器": "1",
    "行情服务器": "",
    "产品名称": "l0",
    "授权编码": "",
    "产品信息": ""
}

# 为了避免泄露账号密码,我这里用了load_json

setting = load_json("connect_ctp.json")

main_engine.connect(setting, "CTP")

# 启动无限循环,阻塞主线程避免退出
while 1:
    # 但如果捕捉到用户主动按下Ctrl-C
    try:
        sleep(2)
    # 则中断循环并退出
    except KeyboardInterrupt:
        print("退出程序")
        break

# 关闭主引擎中的所有模块、接口
main_engine.close()

# 保存所有的文件
global symbol_file_map
for f in symbol_file_map.values():
    f.close()


def process_tick_event(event: Event):
"""接收TICK推送,并进行对应处理"""
tick: TickData = event.data
print(tick.name, tick.symbol, tick.last_price, tick.datetime)

# 将Tick对象转换为数据字典
data = {
    "symbol": tick.symbol,
    "exchange": tick.exchange.value,
    "datetime": tick.datetime.strftime("%Y-%m-%d %H:%M:%S"),
    "open_price": tick.open_price,
    "high_price": tick.high_price,
    "low_price": tick.low_price,
    "last_price": tick.last_price,
    "volume": tick.volume,
    "open_interest": tick.open_interest,
    "bid_price_1": tick.bid_price_1,
    "bid_volume_1": tick.bid_volume_1,
    "ask_price_1": tick.ask_price_1,
    "ask_volume_1": tick.ask_volume_1,
}

# 获取对应的writer对象,并写入
global symbol_writer_map
writer: DictWriter = symbol_writer_map[tick.symbol]
writer.writerow(data)


def process_contract_event(event: Event):
"""收到合约数据后立即订阅其行情"""

# 获取合约对象,并创建对应的行情订阅请求
contract: ContractData = event.data
req = SubscribeRequest(contract.symbol, contract.exchange)

# 获取主引擎全局对象,并调用订阅函数发送订阅
global main_engine
main_engine.subscribe(req, contract.gateway_name)

# 打开对应的CSV文件,并初始化DictWriter
filename = f"{contract.symbol}.csv"

global csv_dir
filepath = csv_dir.joinpath(filename)

# a为后续追加模式,万一中断后则重启继续写入
# newline用于避免在windows上产生多余的一行
f = open(filepath, mode="a", newline="")

fieldnames = [
    "symbol",
    "exchange",
    "datetime",
    "open_price",
    "high_price",
    "low_price",
    "last_price",
    "volume",
    "open_interest",
    "bid_price_1",
    "bid_volume_1",
    "ask_price_1",
    "ask_volume_1",
]

writer = DictWriter(f, fieldnames=fieldnames)
writer.writeheader()

global symbol_file_map
symbol_file_map[contract.symbol] = f

global symbol_writer_map
symbol_writer_map[contract.symbol] = writer


if name == "main":
run()

Member
avatar
加入于:
帖子: 22
声望: 0

开始还可以跑 跑着跑着就出现了上面的系统错误

Member
avatar
加入于:
帖子: 716
声望: 62

f = open(filepath, mode="a", newline="")要配合close使用,否则无法释放资源,或者使用with open。

Member
avatar
加入于:
帖子: 22
声望: 0

Windows PowerShell
版权所有(C) Microsoft Corporation。保留所有权利。

安装最新的 PowerShell,了解新功能和改进!https://aka.ms/PSWindows

PS C:\Users\Hasee> & C:/veighna_studio/python.exe c:/Users/Hasee/Desktop/vnpyFile/实践3/write_csvtts.py
Exception in thread Thread-1 (_run):
Traceback (most recent call last):
File "C:\veighna_studio\lib\threading.py", line 1009, in _bootstrap_inner
self.run()
File "C:\veighna_studio\lib\threading.py", line 946, in run
self._target(*self._args, **self._kwargs)
File "C:\veighna_studio\lib\site-packages\vnpy\event\engine.py", line 60, in _run
self._process(event)
File "C:\veighna_studio\lib\site-packages\vnpy\event\engine.py", line 73, in _process
[handler(event) for handler in self._handlers[event.type]]
File "C:\veighna_studio\lib\site-packages\vnpy\event\engine.py", line 73, in <listcomp>
[handler(event) for handler in self._handlers[event.type]]
File "c:\Users\Hasee\Desktop\vnpyFile\实践3\write_csvtts.py", line 143, in process_contract_event
writer.writeheader()
File "C:\veighna_studio\lib\csv.py", line 143, in writeheader
return self.writerow(header)
File "C:\veighna_studio\lib\csv.py", line 154, in writerow
return self.writer.writerow(self._dict_to_list(rowdict))
ValueError: I/O operation on closed file.
KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

KeyError: ('TTS',)

At:
C:\veighna_studio\lib\site-packages\vnpy_ctp\gateway\ctp_gateway.py(603): onRspQryInstrument

Member
avatar
加入于:
帖子: 22
声望: 0

老师,这是什么错误

Member
avatar
加入于:
帖子: 4703
声望: 287

不知道你的具体代码了,tts不能和ctp一起连

© 2015-2022 上海韦纳软件科技有限公司
备案服务号:沪ICP备18006526号

沪公网安备 31011502017034号

【用户协议】
【隐私政策】
【免责条款】