importar pandas como pd Importação Async Client importar datetime, timedelta import aiohttp Importar json def utc_to_local ((utc_dt): # Convert para Beijing local_tz = datetime.timezone ((datetime.timedelta ((hours=8)) # Distância horária do Distrito 8 local_dt = utc_dt.replace ((tzinfo=datetime.timezone.utc).astimezone ((local_tz)) return local_dt
async def init_client ((): cliente = aguardar AsyncClient.create ((api_key=api_key, api_secret=api_secret)
return client
async def get_klines ((cliente, símbolo, tempo de início, tempo de fim, intervalo):
klines = espera cliente.futures_klines ((simbolo=simbolo, intervalo=intervalo, startTime=start_time.timestamp))) *1000, endTime=end_time.timestamp))) *1000)
df = pd.DataFrame(linhas, colunas=[
Async def close_client ((client): Aguardar cliente.close_connection()
Async def main (:
client = await init_client (em inglês)
# Obtenção de todos os pares de transações de contratos USDT permanentes
exchange_info = aguardar cliente.futures_exchange_info
symbols = [symbol_info [
# 将所有交易对添加到 DataFrame 中
for symbol in symbols:
df.loc[symbol] = [None] * len(df.columns)
# 遍历所有交易对
for symbol in symbols:
# 设置起止时间
start_time = datetime.utcnow() - timedelta(minutes=16)#开始时间为16分钟前
end_time = datetime.utcnow()
try:
# 获取M15k线
current_klines = await get_klines(client, symbol, end_time - timedelta(minutes=15), end_time, '15m')
except Exception as e:
Log(f"An error occurred: {e}")
current_klines = []
# 将数据存入 DataFrame
# 更新对应的行
df.loc[symbol, 'Open'] = current_klines['open'].iloc[-1]
df.loc[symbol, 'High'] = current_klines['high'].iloc[-1]
df.loc[symbol, 'Low'] = current_klines['low'].iloc[-1]
df.loc[symbol, 'Close'] = current_klines['close'].iloc[-1]
df.loc[symbol, 'Change'] = current_change
df.loc[symbol, 'Volume'] = current_klines['volume'].iloc[-1]
# 关闭客户端
Log(df)
await close_client(client)
senome == ‘principal
Log ((df) uma vez depois, o erro ocorre; ou seja, uma vez atualizado o preço de todos os símbolos e outros dados, o erro ocorre: Traceback (most recent call last):init_ctxArquivo
Não sePode ser coletado através de vários fios, colocando cada fio de dados coletados em um objeto público; e então julgar se todos os fios terminaram.
- O quê?Afinal, o sonho é sempre uma palavra-chave ou duas sobre funções de agregação?
- O quê?Afinal, o sonho é sempre uma palavra-chave ou duas sobre funções de agregação?
Ervas daninhasNão usei a biblioteca, mas é melhor fazer o debug passo a passo. Também não é muito bom fazer centenas de transações em simultâneo diretamente. É mais fácil registrar você mesmo com uma interface de mercado agregada.
Ervas daninhas/fapi/v1/ticker/price