6
Подписаться
879
Подписчики

Краткое руководство по началу работы с API Polymarket

Создано: 2026-02-14 19:04:34, Обновлено: 2026-02-18 22:00:17
comments   0
hits   394

Краткое руководство по началу работы с API Polymarket

Построен на платформе FMZ (Торжественная версия 3.8.8) и быстро справляется с API Polymarket.


Формат символов

Symbol должна бытьexchange.GetMarkets()Функция возвращает точное значение ключа, вызывается медленно и затем кэшируется. Формат:

{marketSlug}_USDC.(Yes/No)

Пример:

will-the-next-prime-minister-of-hungary-be-istvn-kapitny_USDC.No
  • YesТокен = событие ставкиСобраниеПроизошло
  • NoТокен = событие ставкиНет, не будет.Произошло
  • Ценовой диапазон от 0 до 1 представляет вероятность того, что рынок считает ((0.65 = 65%)

Сценарий 1: Получить все рынки ((получить действительный символ)

var markets = exchange.GetMarkets();
for (var symbol in markets) {
    var m = markets[symbol];
    Log(symbol);  // 这就是下单用的symbol
    Log("  问题:", m.Info.question);
    Log("  24h量:", m.Info.volume24hr);
}

Сценарий 2: Поиск информации

// symbol必须从GetMarkets()的key中获取
var symbol = "will-the-next-prime-minister-of-hungary-be-istvn-kapitny_USDC.Yes";

// ticker
var t = exchange.GetTicker(symbol);
Log("最新价:", t.Last, "买一:", t.Buy, "卖一:", t.Sell);

// 深度
var d = exchange.GetDepth(symbol);
Log("卖一:", d.Asks[0].Price, d.Asks[0].Amount);
Log("买一:", d.Bids[0].Price, d.Bids[0].Amount);

Сценарий 3: проверка счетов и хранение

// 账户
var acc = exchange.GetAccount();
Log("可用:", acc.Balance, "USDC");

// 持仓
var pos = exchange.GetPositions();
for (var i = 0; i < pos.length; i++) {
    Log(pos[i].Symbol, "数量:", pos[i].Amount, "盈亏:", pos[i].Profit);
}

Сцена 4: Заказ.

// symbol必须从GetMarkets()获取
var symbol = "{some-market}_USDC.Yes";

// 市价买入 10 USDC
exchange.CreateOrder(symbol, "buy", -1, 10);

// 限价买入
exchange.CreateOrder(symbol, "buy", 0.55, 20);

// 卖出
exchange.CreateOrder(symbol, "sell", -1, 10);

Сценарий 5: проверка/отзыв

// 查询订单
var order = exchange.GetOrder(orderId);
Log("状态:", order.Status, "成交:", order.DealAmount);

// 撤单
exchange.CancelOrder(orderId);

// 所有未成交订单
var orders = exchange.GetOrders();

Сцена 6: Погашение

var pos = exchange.GetPositions();
for (var i = 0; i < pos.length; i++) {
    if (pos[i].Amount > 0) {
        exchange.CreateOrder(pos[i].Symbol, "sell", -1, pos[i].Amount);
    }
    Sleep(500);
}

Сцена 7: “Искупление” возвращается

var items = _C(exchange.GetPositions);
items.forEach(item => {
    if (item.Info.redeemable) {
        Log(item.Symbol, item.Info.eventSlug)
        Log(exchange.IO("redeem", item.Symbol, true))
    }
})


Сценарий 8: Поиск низковероятных показателей на рынке

var markets = exchange.GetMarkets();
for (var symbol in markets) {
    if (!symbol.endsWith("-YES")) continue;
    var prices = JSON.parse(markets[symbol].Info.outcomePrices || "[]");
    var yesPrice = parseFloat(prices[0] || 0);
    if (yesPrice < 0.3 && yesPrice > 0.05) {
        Log(symbol, "YES价格:", (yesPrice * 100).toFixed(1) + "%");
    }
}

Часто используемые API

Способ проиллюстрировать
GetMarkets() В этом случае вы получите доступ ко всем рынкам, а возвращенный ключ - это действительный символ.
GetTicker(symbol) “Последнее, купи, продай”
GetDepth(symbol) Поиск подробности {Asks, Bids}
GetAccount() Остаток счета {Balance, FrozenBalance}
GetPositions() Список позиций [{Symbol, Amount, Profit}]
CreateOrder(symbol, side, price, amount) Заказ, цена = -1, рыночная цена
CancelOrder(orderId) Отменить заказ
GetOrder(orderId) Поисковый лист
GetOrders() Невыполненные заказы

side: "buy" / "sell"