import panda sebagai pd dari binance.client import AsyncClient dari datetime import datetime, timedelta import aiohttp import json def utc_to_local ((utc_dt):# Konversi ke waktu Beijing local_tz = datetime.timezone ((datetime.timedelta ((hours=8)) # perbedaan waktu zona delapan timur local_dt = utc_dt.replace ((tzinfo=datetime.timezone.utc).astimezone ((local_tz)) return local_dt
async def init_client ((): klien = menunggu AsyncClient.create ((api_key=api_key, api_secret=api_secret)
return client
async def get_klines ((client, simbol, start_time, end_time, interval):
klines = menunggu klien.futures_klines ((simbol=simbol, interval=interval, startTime=start_time.timestamp() *1000, endTime=end_time.timestamp() *1000)
df = pd.DataFrame(klines, columns=[
async def close_client ((klient): menunggu client.close_connection ((()
Async def main (:
client = tunggu init_client
# Dapatkan semua pasangan transaksi kontrak USDT permanen
exchange_info = tunggu klien.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)
Jikanama == ‘utama
Log ((df) setelah satu kali akan mengalami kesalahan; yaitu setelah satu kali memperbarui semua simbol harga dan data lainnya akan mengalami kesalahan:Traceback (most recent call last): File bar, line 1246, ininit_ctxFile
Tidak jikaAnda dapat mengumpulkan data melalui beberapa thread, menempatkan data yang dikumpulkan dari setiap thread ke dalam satu objek publik, dan kemudian menilai apakah semua thread berakhir.
Aku tidak tahu.Apakah mimpi selalu menyebutkan satu atau dua kata kunci tentang fungsi agregat?
Aku tidak tahu.Apakah mimpi selalu menyebutkan satu atau dua kata kunci tentang fungsi agregat?
RumputSaya belum pernah menggunakan perpustakaan ini, tetapi lebih baik untuk melakukan debugging langkah demi langkah. Selain itu, melakukan ratusan transaksi secara langsung secara bersamaan juga tidak terlalu baik.
Rumput/fapi/v1/ticker/price