29 个稳定版本

1.0.31 2024 年 8 月 22 日
1.0.29 2024 年 7 月 26 日
1.0.20 2024 年 3 月 29 日
1.0.5 2023 年 12 月 14 日
1.0.1 2023 年 11 月 21 日

802网页编程

Download history 256/week @ 2024-05-16 61/week @ 2024-05-23 291/week @ 2024-06-06 54/week @ 2024-06-13 11/week @ 2024-06-20 2/week @ 2024-07-04 142/week @ 2024-07-25 8/week @ 2024-08-01

每月 150 次下载

MIT/Apache

335KB
7K SLoC

LongPort OpenAPI SDK for Rust

longport 为调用 LongPort OpenAPI 提供了一个易于使用的接口。

快速入门

将依赖项添加到 Cargo.toml

[dependencies]
longport = "1.0.0"

设置环境变量(MacOS/Linux)

export LONGPORT_APP_KEY="App Key get from user center"
export LONGPORT_APP_SECRET="App Secret get from user center"
export LONGPORT_ACCESS_TOKEN="Access Token get from user center"

设置环境变量(Windows)

setx LONGPORT_APP_KEY "App Key get from user center"
setx LONGPORT_APP_SECRET "App Secret get from user center"
setx LONGPORT_ACCESS_TOKEN "Access Token get from user center"

引用 API (获取证券的基本信息)

use std::sync::Arc;

use longport::{
    decimal,
    trade::{OrderSide, OrderType, SubmitOrderOptions, TimeInForceType},
    Config, QuoteContext, TradeContext,
};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Load configuration from environment variables
    let config = Arc::new(Config::from_env()?);

    // Create a context for quote APIs
    let (ctx, _) = QuoteContext::try_new(config.clone()).await?;

    // Get basic information of securities
    let resp = ctx
        .quote(["700.HK", "AAPL.US", "TSLA.US", "NFLX.US"])
        .await?;
    println!("{:?}", resp);

    Ok(())
}

引用 API (订阅报价)

use std::sync::Arc;

use longport::{quote::SubFlags, Config, QuoteContext};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Load configuration from environment variables
    let config = Arc::new(Config::from_env()?);

    // Create a context for quote APIs
    let (ctx, mut receiver) = QuoteContext::try_new(config).await?;

    // Subscribe
    ctx.subscribe(["700.HK"], SubFlags::QUOTE, true).await?;

    // Receive push events
    while let Some(event) = receiver.recv().await {
        println!("{:?}", event);
    }

    Ok(())
}

交易 API (提交订单)

use std::sync::Arc;

use longport::{
    decimal,
    trade::{OrderSide, OrderType, SubmitOrderOptions, TimeInForceType},
    Config, TradeContext,
};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Load configuration from environment variables
    let config = Arc::new(Config::from_env()?);

    // Create a context for trade APIs
    let (ctx, _) = TradeContext::try_new(config).await?;

    // Submit order
    let opts = SubmitOrderOptions::new(
        "700.HK",
        OrderType::LO,
        OrderSide::Buy,
        500,
        TimeInForceType::Day,
    )
    .submitted_price(decimal!(50i32))
    .remark("Hello from Rust SDK".to_string());

    let resp = ctx.submit_order(opts).await?;
    println!("{:?}", resp);

    Ok(())
}

包功能

为了避免编译未使用的依赖项,longport 限制了某些功能,所有这些功能默认都是禁用的

功能 描述
blocking 提供 blocking 客户端 API。

许可证

根据以下之一许可

依赖项

~13–26MB
~391K SLoC