{"id":28693450,"url":"https://github.com/ccxt/bitmart-python","last_synced_at":"2025-10-28T20:51:08.624Z","repository":{"id":283541235,"uuid":"950782713","full_name":"ccxt/bitmart-python","owner":"ccxt","description":null,"archived":false,"fork":false,"pushed_at":"2025-10-27T17:21:04.000Z","size":1681,"stargazers_count":7,"open_issues_count":0,"forks_count":0,"subscribers_count":4,"default_branch":"main","last_synced_at":"2025-10-27T19:17:05.115Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/ccxt.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-03-18T17:18:45.000Z","updated_at":"2025-10-27T17:21:09.000Z","dependencies_parsed_at":"2025-03-20T20:11:28.241Z","dependency_job_id":"57809ab7-b87a-447a-8c4b-30c13da99a45","html_url":"https://github.com/ccxt/bitmart-python","commit_stats":null,"previous_names":["ccxt/bitmart-python"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/ccxt/bitmart-python","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ccxt%2Fbitmart-python","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ccxt%2Fbitmart-python/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ccxt%2Fbitmart-python/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ccxt%2Fbitmart-python/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/ccxt","download_url":"https://codeload.github.com/ccxt/bitmart-python/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/ccxt%2Fbitmart-python/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":281512674,"owners_count":26514301,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-28T02:00:06.022Z","response_time":60,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-06-14T08:30:32.001Z","updated_at":"2025-10-28T20:51:08.618Z","avatar_url":"https://github.com/ccxt.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# bitmart-python\nPython SDK (sync and async) for Bitmart cryptocurrency exchange with Rest and WS capabilities.\n\n- You can check the SDK docs here: [SDK](https://docs.ccxt.com/#/exchanges/bitmart)\n- You can check Bitmart's docs here: [Docs](https://www.google.com/search?q=google+bitmart+cryptocurrency+exchange+api+docs)\n- Github repo: https://github.com/ccxt/bitmart-python\n- Pypi package: https://pypi.org/project/bitmart\n\n\n## Installation\n\n```\npip install bitmart\n```\n\n## Usage\n\n### Sync\n\n```Python\nfrom bitmart import BitmartSync\n\ndef main():\n    instance = BitmartSync({})\n    ob =  instance.fetch_order_book(\"BTC/USDC\")\n    print(ob)\n    #\n    # balance = instance.fetch_balance()\n    # order = instance.create_order(\"BTC/USDC\", \"limit\", \"buy\", 1, 100000)\n\nmain()\n```\n\n### Async\n\n```Python\nimport sys\nimport asyncio\nfrom bitmart import BitmartAsync\n\n### on Windows, uncomment below:\n# if sys.platform == 'win32':\n# \tasyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy())\n\nasync def main():\n    instance = BitmartAsync({})\n    ob =  await instance.fetch_order_book(\"BTC/USDC\")\n    print(ob)\n    #\n    # balance = await instance.fetch_balance()\n    # order = await instance.create_order(\"BTC/USDC\", \"limit\", \"buy\", 1, 100000)\n\n    # once you are done with the exchange\n    await instance.close()\n\nasyncio.run(main())\n```\n\n\n\n### Websockets\n\n```Python\nimport sys\nfrom bitmart import BitmartWs\n\n### on Windows, uncomment below:\n# if sys.platform == 'win32':\n# \tasyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy())\n\nasync def main():\n    instance = BitmartWs({})\n    while True:\n        ob = await instance.watch_order_book(\"BTC/USDC\")\n        print(ob)\n        # orders = await instance.watch_orders(\"BTC/USDC\")\n\n    # once you are done with the exchange\n    await instance.close()\n\nasyncio.run(main())\n```\n\n\n\n\n\n#### Raw call\n\nYou can also construct custom requests to available \"implicit\" endpoints\n\n```Python\n        request = {\n            'type': 'candleSnapshot',\n            'req': {\n                'coin': coin,\n                'interval': tf,\n                'startTime': since,\n                'endTime': until,\n            },\n        }\n        response = await instance.public_post_info(request)\n```\n\n\n## Available methods\n\n### REST Unified\n\n- `create_market_buy_order_with_cost(self, symbol: str, cost: float, params={})`\n- `create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={})`\n- `create_orders(self, orders: List[OrderRequest], params={})`\n- `create_spot_order_request(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={})`\n- `create_swap_order_request(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={})`\n- `fetch_balance(self, params={})`\n- `fetch_borrow_interest(self, code: Str = None, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_canceled_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_closed_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_contract_markets(self, params={})`\n- `fetch_currencies(self, params={})`\n- `fetch_deposit_address(self, code: str, params={})`\n- `fetch_deposit_withdraw_fee(self, code: str, params={})`\n- `fetch_deposit(self, id: str, code: Str = None, params={})`\n- `fetch_deposits(self, code: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_funding_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_funding_rate_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_funding_rate(self, symbol: str, params={})`\n- `fetch_isolated_borrow_rate(self, symbol: str, params={})`\n- `fetch_isolated_borrow_rates(self, params={})`\n- `fetch_ledger(self, code: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_markets(self, params={})`\n- `fetch_my_liquidations(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_ohlcv(self, symbol: str, timeframe: str = '1m', since: Int = None, limit: Int = None, params={})`\n- `fetch_open_interest(self, symbol: str, params={})`\n- `fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_order_book(self, symbol: str, limit: Int = None, params={})`\n- `fetch_order_trades(self, id: str, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_order(self, id: str, symbol: Str = None, params={})`\n- `fetch_orders_by_status(self, status, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_position_mode(self, symbol: Str = None, params={})`\n- `fetch_position(self, symbol: str, params={})`\n- `fetch_positions(self, symbols: Strings = None, params={})`\n- `fetch_spot_markets(self, params={})`\n- `fetch_status(self, params={})`\n- `fetch_ticker(self, symbol: str, params={})`\n- `fetch_tickers(self, symbols: Strings = None, params={})`\n- `fetch_time(self, params={})`\n- `fetch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={})`\n- `fetch_trading_fee(self, symbol: str, params={})`\n- `fetch_transaction_fee(self, code: str, params={})`\n- `fetch_transactions_by_type(self, type, code: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_transactions_request(self, flowType: Int = None, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_transfers(self, code: Str = None, since: Int = None, limit: Int = None, params={})`\n- `fetch_withdraw_addresses(self, code: str, note=None, networkCode=None, params={})`\n- `fetch_withdrawal(self, id: str, code: Str = None, params={})`\n- `fetch_withdrawals(self, code: Str = None, since: Int = None, limit: Int = None, params={})`\n- `borrow_isolated_margin(self, symbol: str, code: str, amount: float, params={})`\n- `cancel_all_orders(self, symbol: Str = None, params={})`\n- `cancel_order(self, id: str, symbol: Str = None, params={})`\n- `cancel_orders(self, ids: List[str], symbol: Str = None, params={})`\n- `custom_parse_balance(self, response, marketType)`\n- `describe(self)`\n- `edit_order(self, id: str, symbol: str, type: OrderType, side: OrderSide, amount: Num = None, price: Num = None, params={})`\n- `get_currency_id_from_code_and_network(self, currencyCode: Str, networkCode: Str)`\n- `nonce(self)`\n- `repay_isolated_margin(self, symbol: str, code: str, amount, params={})`\n- `set_leverage(self, leverage: int, symbol: Str = None, params={})`\n- `set_position_mode(self, hedged: bool, symbol: Str = None, params={})`\n- `transfer(self, code: str, amount: float, fromAccount: str, toAccount: str, params={})`\n- `withdraw(self, code: str, amount: float, address: str, tag: Str = None, params={})`\n\n### REST Raw\n\n- `public_get_system_time(request)`\n- `public_get_system_service(request)`\n- `public_get_spot_v1_currencies(request)`\n- `public_get_spot_v1_symbols(request)`\n- `public_get_spot_v1_symbols_details(request)`\n- `public_get_spot_quotation_v3_tickers(request)`\n- `public_get_spot_quotation_v3_ticker(request)`\n- `public_get_spot_quotation_v3_lite_klines(request)`\n- `public_get_spot_quotation_v3_klines(request)`\n- `public_get_spot_quotation_v3_books(request)`\n- `public_get_spot_quotation_v3_trades(request)`\n- `public_get_spot_v1_ticker(request)`\n- `public_get_spot_v2_ticker(request)`\n- `public_get_spot_v1_ticker_detail(request)`\n- `public_get_spot_v1_steps(request)`\n- `public_get_spot_v1_symbols_kline(request)`\n- `public_get_spot_v1_symbols_book(request)`\n- `public_get_spot_v1_symbols_trades(request)`\n- `public_get_contract_v1_tickers(request)`\n- `public_get_contract_public_details(request)`\n- `public_get_contract_public_depth(request)`\n- `public_get_contract_public_open_interest(request)`\n- `public_get_contract_public_funding_rate(request)`\n- `public_get_contract_public_funding_rate_history(request)`\n- `public_get_contract_public_kline(request)`\n- `public_get_account_v1_currencies(request)`\n- `public_get_contract_public_markprice_kline(request)`\n- `private_get_account_sub_account_v1_transfer_list(request)`\n- `private_get_account_sub_account_v1_transfer_history(request)`\n- `private_get_account_sub_account_main_v1_wallet(request)`\n- `private_get_account_sub_account_main_v1_subaccount_list(request)`\n- `private_get_account_contract_sub_account_main_v1_wallet(request)`\n- `private_get_account_contract_sub_account_main_v1_transfer_list(request)`\n- `private_get_account_contract_sub_account_v1_transfer_history(request)`\n- `private_get_account_v1_wallet(request)`\n- `private_get_account_v1_currencies(request)`\n- `private_get_spot_v1_wallet(request)`\n- `private_get_account_v1_deposit_address(request)`\n- `private_get_account_v1_withdraw_charge(request)`\n- `private_get_account_v2_deposit_withdraw_history(request)`\n- `private_get_account_v1_deposit_withdraw_detail(request)`\n- `private_get_account_v1_withdraw_address_list(request)`\n- `private_get_spot_v1_order_detail(request)`\n- `private_get_spot_v2_orders(request)`\n- `private_get_spot_v1_trades(request)`\n- `private_get_spot_v2_trades(request)`\n- `private_get_spot_v3_orders(request)`\n- `private_get_spot_v2_order_detail(request)`\n- `private_get_spot_v1_margin_isolated_borrow_record(request)`\n- `private_get_spot_v1_margin_isolated_repay_record(request)`\n- `private_get_spot_v1_margin_isolated_pairs(request)`\n- `private_get_spot_v1_margin_isolated_account(request)`\n- `private_get_spot_v1_trade_fee(request)`\n- `private_get_spot_v1_user_fee(request)`\n- `private_get_spot_v1_broker_rebate(request)`\n- `private_get_contract_private_assets_detail(request)`\n- `private_get_contract_private_order(request)`\n- `private_get_contract_private_order_history(request)`\n- `private_get_contract_private_position(request)`\n- `private_get_contract_private_position_v2(request)`\n- `private_get_contract_private_get_open_orders(request)`\n- `private_get_contract_private_current_plan_order(request)`\n- `private_get_contract_private_trades(request)`\n- `private_get_contract_private_position_risk(request)`\n- `private_get_contract_private_affilate_rebate_list(request)`\n- `private_get_contract_private_affilate_trade_list(request)`\n- `private_get_contract_private_transaction_history(request)`\n- `private_get_contract_private_get_position_mode(request)`\n- `private_post_account_sub_account_main_v1_sub_to_main(request)`\n- `private_post_account_sub_account_sub_v1_sub_to_main(request)`\n- `private_post_account_sub_account_main_v1_main_to_sub(request)`\n- `private_post_account_sub_account_sub_v1_sub_to_sub(request)`\n- `private_post_account_sub_account_main_v1_sub_to_sub(request)`\n- `private_post_account_contract_sub_account_main_v1_sub_to_main(request)`\n- `private_post_account_contract_sub_account_main_v1_main_to_sub(request)`\n- `private_post_account_contract_sub_account_sub_v1_sub_to_main(request)`\n- `private_post_account_v1_withdraw_apply(request)`\n- `private_post_spot_v1_submit_order(request)`\n- `private_post_spot_v1_batch_orders(request)`\n- `private_post_spot_v2_cancel_order(request)`\n- `private_post_spot_v1_cancel_orders(request)`\n- `private_post_spot_v4_query_order(request)`\n- `private_post_spot_v4_query_client_order(request)`\n- `private_post_spot_v4_query_open_orders(request)`\n- `private_post_spot_v4_query_history_orders(request)`\n- `private_post_spot_v4_query_trades(request)`\n- `private_post_spot_v4_query_order_trades(request)`\n- `private_post_spot_v4_cancel_orders(request)`\n- `private_post_spot_v4_cancel_all(request)`\n- `private_post_spot_v4_batch_orders(request)`\n- `private_post_spot_v3_cancel_order(request)`\n- `private_post_spot_v2_batch_orders(request)`\n- `private_post_spot_v2_submit_order(request)`\n- `private_post_spot_v1_margin_submit_order(request)`\n- `private_post_spot_v1_margin_isolated_borrow(request)`\n- `private_post_spot_v1_margin_isolated_repay(request)`\n- `private_post_spot_v1_margin_isolated_transfer(request)`\n- `private_post_account_v1_transfer_contract_list(request)`\n- `private_post_account_v1_transfer_contract(request)`\n- `private_post_contract_private_submit_order(request)`\n- `private_post_contract_private_cancel_order(request)`\n- `private_post_contract_private_cancel_orders(request)`\n- `private_post_contract_private_submit_plan_order(request)`\n- `private_post_contract_private_cancel_plan_order(request)`\n- `private_post_contract_private_submit_leverage(request)`\n- `private_post_contract_private_submit_tp_sl_order(request)`\n- `private_post_contract_private_modify_plan_order(request)`\n- `private_post_contract_private_modify_preset_plan_order(request)`\n- `private_post_contract_private_modify_limit_order(request)`\n- `private_post_contract_private_modify_tp_sl_order(request)`\n- `private_post_contract_private_submit_trail_order(request)`\n- `private_post_contract_private_cancel_trail_order(request)`\n- `private_post_contract_private_set_position_mode(request)`\n\n### WS Unified\n\n- `describe(self)`\n- `subscribe(self, channel, symbol, type, params={})`\n- `subscribe_multiple(self, channel: str, type: str, symbols: Strings = None, params={})`\n- `watch_balance(self, params={})`\n- `set_balance_cache(self, client: Client, type, subscribeHash)`\n- `load_balance_snapshot(self, client, messageHash, type)`\n- `watch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={})`\n- `watch_trades_for_symbols(self, symbols: List[str], since: Int = None, limit: Int = None, params={})`\n- `get_params_for_multiple_sub(self, methodName: str, symbols: List[str], limit: Int = None, params={})`\n- `watch_ticker(self, symbol: str, params={})`\n- `watch_tickers(self, symbols: Strings = None, params={})`\n- `watch_bids_asks(self, symbols: Strings = None, params={})`\n- `watch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={})`\n- `watch_positions(self, symbols: Strings = None, since: Int = None, limit: Int = None, params={})`\n- `watch_ohlcv(self, symbol: str, timeframe: str = '1m', since: Int = None, limit: Int = None, params={})`\n- `watch_order_book(self, symbol: str, limit: Int = None, params={})`\n- `watch_order_book_for_symbols(self, symbols: List[str], limit: Int = None, params={})`\n- `authenticate(self, type, params={})`\n\n## Contribution\n- Give us a star :star:\n- Fork and Clone! Awesome\n- Select existing issues or create a new issue.","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fccxt%2Fbitmart-python","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fccxt%2Fbitmart-python","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fccxt%2Fbitmart-python/lists"}