[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"similar-thrasher-corp--gocryptotrader":3,"tool-thrasher-corp--gocryptotrader":61},[4,18,26,36,44,53],{"id":5,"name":6,"github_repo":7,"description_zh":8,"stars":9,"difficulty_score":10,"last_commit_at":11,"category_tags":12,"status":17},4358,"openclaw","openclaw\u002Fopenclaw","OpenClaw 是一款专为个人打造的本地化 AI 助手，旨在让你在自己的设备上拥有完全可控的智能伙伴。它打破了传统 AI 助手局限于特定网页或应用的束缚，能够直接接入你日常使用的各类通讯渠道，包括微信、WhatsApp、Telegram、Discord、iMessage 等数十种平台。无论你在哪个聊天软件中发送消息，OpenClaw 都能即时响应，甚至支持在 macOS、iOS 和 Android 设备上进行语音交互，并提供实时的画布渲染功能供你操控。\n\n这款工具主要解决了用户对数据隐私、响应速度以及“始终在线”体验的需求。通过将 AI 部署在本地，用户无需依赖云端服务即可享受快速、私密的智能辅助，真正实现了“你的数据，你做主”。其独特的技术亮点在于强大的网关架构，将控制平面与核心助手分离，确保跨平台通信的流畅性与扩展性。\n\nOpenClaw 非常适合希望构建个性化工作流的技术爱好者、开发者，以及注重隐私保护且不愿被单一生态绑定的普通用户。只要具备基础的终端操作能力（支持 macOS、Linux 及 Windows WSL2），即可通过简单的命令行引导完成部署。如果你渴望拥有一个懂你",349277,3,"2026-04-06T06:32:30",[13,14,15,16],"Agent","开发框架","图像","数据工具","ready",{"id":19,"name":20,"github_repo":21,"description_zh":22,"stars":23,"difficulty_score":10,"last_commit_at":24,"category_tags":25,"status":17},3808,"stable-diffusion-webui","AUTOMATIC1111\u002Fstable-diffusion-webui","stable-diffusion-webui 是一个基于 Gradio 构建的网页版操作界面，旨在让用户能够轻松地在本地运行和使用强大的 Stable Diffusion 图像生成模型。它解决了原始模型依赖命令行、操作门槛高且功能分散的痛点，将复杂的 AI 绘图流程整合进一个直观易用的图形化平台。\n\n无论是希望快速上手的普通创作者、需要精细控制画面细节的设计师，还是想要深入探索模型潜力的开发者与研究人员，都能从中获益。其核心亮点在于极高的功能丰富度：不仅支持文生图、图生图、局部重绘（Inpainting）和外绘（Outpainting）等基础模式，还独创了注意力机制调整、提示词矩阵、负向提示词以及“高清修复”等高级功能。此外，它内置了 GFPGAN 和 CodeFormer 等人脸修复工具，支持多种神经网络放大算法，并允许用户通过插件系统无限扩展能力。即使是显存有限的设备，stable-diffusion-webui 也提供了相应的优化选项，让高质量的 AI 艺术创作变得触手可及。",162132,"2026-04-05T11:01:52",[14,15,13],{"id":27,"name":28,"github_repo":29,"description_zh":30,"stars":31,"difficulty_score":32,"last_commit_at":33,"category_tags":34,"status":17},1381,"everything-claude-code","affaan-m\u002Feverything-claude-code","everything-claude-code 是一套专为 AI 编程助手（如 Claude Code、Codex、Cursor 等）打造的高性能优化系统。它不仅仅是一组配置文件，而是一个经过长期实战打磨的完整框架，旨在解决 AI 代理在实际开发中面临的效率低下、记忆丢失、安全隐患及缺乏持续学习能力等核心痛点。\n\n通过引入技能模块化、直觉增强、记忆持久化机制以及内置的安全扫描功能，everything-claude-code 能显著提升 AI 在复杂任务中的表现，帮助开发者构建更稳定、更智能的生产级 AI 代理。其独特的“研究优先”开发理念和针对 Token 消耗的优化策略，使得模型响应更快、成本更低，同时有效防御潜在的攻击向量。\n\n这套工具特别适合软件开发者、AI 研究人员以及希望深度定制 AI 工作流的技术团队使用。无论您是在构建大型代码库，还是需要 AI 协助进行安全审计与自动化测试，everything-claude-code 都能提供强大的底层支持。作为一个曾荣获 Anthropic 黑客大奖的开源项目，它融合了多语言支持与丰富的实战钩子（hooks），让 AI 真正成长为懂上",156033,2,"2026-04-14T23:32:00",[14,13,35],"语言模型",{"id":37,"name":38,"github_repo":39,"description_zh":40,"stars":41,"difficulty_score":32,"last_commit_at":42,"category_tags":43,"status":17},2271,"ComfyUI","Comfy-Org\u002FComfyUI","ComfyUI 是一款功能强大且高度模块化的视觉 AI 引擎，专为设计和执行复杂的 Stable Diffusion 图像生成流程而打造。它摒弃了传统的代码编写模式，采用直观的节点式流程图界面，让用户通过连接不同的功能模块即可构建个性化的生成管线。\n\n这一设计巧妙解决了高级 AI 绘图工作流配置复杂、灵活性不足的痛点。用户无需具备编程背景，也能自由组合模型、调整参数并实时预览效果，轻松实现从基础文生图到多步骤高清修复等各类复杂任务。ComfyUI 拥有极佳的兼容性，不仅支持 Windows、macOS 和 Linux 全平台，还广泛适配 NVIDIA、AMD、Intel 及苹果 Silicon 等多种硬件架构，并率先支持 SDXL、Flux、SD3 等前沿模型。\n\n无论是希望深入探索算法潜力的研究人员和开发者，还是追求极致创作自由度的设计师与资深 AI 绘画爱好者，ComfyUI 都能提供强大的支持。其独特的模块化架构允许社区不断扩展新功能，使其成为当前最灵活、生态最丰富的开源扩散模型工具之一，帮助用户将创意高效转化为现实。",108322,"2026-04-10T11:39:34",[14,15,13],{"id":45,"name":46,"github_repo":47,"description_zh":48,"stars":49,"difficulty_score":32,"last_commit_at":50,"category_tags":51,"status":17},6121,"gemini-cli","google-gemini\u002Fgemini-cli","gemini-cli 是一款由谷歌推出的开源 AI 命令行工具，它将强大的 Gemini 大模型能力直接集成到用户的终端环境中。对于习惯在命令行工作的开发者而言，它提供了一条从输入提示词到获取模型响应的最短路径，无需切换窗口即可享受智能辅助。\n\n这款工具主要解决了开发过程中频繁上下文切换的痛点，让用户能在熟悉的终端界面内直接完成代码理解、生成、调试以及自动化运维任务。无论是查询大型代码库、根据草图生成应用，还是执行复杂的 Git 操作，gemini-cli 都能通过自然语言指令高效处理。\n\n它特别适合广大软件工程师、DevOps 人员及技术研究人员使用。其核心亮点包括支持高达 100 万 token 的超长上下文窗口，具备出色的逻辑推理能力；内置 Google 搜索、文件操作及 Shell 命令执行等实用工具；更独特的是，它支持 MCP（模型上下文协议），允许用户灵活扩展自定义集成，连接如图像生成等外部能力。此外，个人谷歌账号即可享受免费的额度支持，且项目基于 Apache 2.0 协议完全开源，是提升终端工作效率的理想助手。",100752,"2026-04-10T01:20:03",[52,13,15,14],"插件",{"id":54,"name":55,"github_repo":56,"description_zh":57,"stars":58,"difficulty_score":32,"last_commit_at":59,"category_tags":60,"status":17},4721,"markitdown","microsoft\u002Fmarkitdown","MarkItDown 是一款由微软 AutoGen 团队打造的轻量级 Python 工具，专为将各类文件高效转换为 Markdown 格式而设计。它支持 PDF、Word、Excel、PPT、图片（含 OCR）、音频（含语音转录）、HTML 乃至 YouTube 链接等多种格式的解析，能够精准提取文档中的标题、列表、表格和链接等关键结构信息。\n\n在人工智能应用日益普及的今天，大语言模型（LLM）虽擅长处理文本，却难以直接读取复杂的二进制办公文档。MarkItDown 恰好解决了这一痛点，它将非结构化或半结构化的文件转化为模型“原生理解”且 Token 效率极高的 Markdown 格式，成为连接本地文件与 AI 分析 pipeline 的理想桥梁。此外，它还提供了 MCP（模型上下文协议）服务器，可无缝集成到 Claude Desktop 等 LLM 应用中。\n\n这款工具特别适合开发者、数据科学家及 AI 研究人员使用，尤其是那些需要构建文档检索增强生成（RAG）系统、进行批量文本分析或希望让 AI 助手直接“阅读”本地文件的用户。虽然生成的内容也具备一定可读性，但其核心优势在于为机器",93400,"2026-04-06T19:52:38",[52,14],{"id":62,"github_repo":63,"name":64,"description_en":65,"description_zh":66,"ai_summary_zh":66,"readme_en":67,"readme_zh":68,"quickstart_zh":69,"use_case_zh":70,"hero_image_url":71,"owner_login":72,"owner_name":73,"owner_avatar_url":74,"owner_bio":75,"owner_company":76,"owner_location":76,"owner_email":77,"owner_twitter":76,"owner_website":78,"owner_url":79,"languages":80,"stars":105,"forks":106,"last_commit_at":107,"license":108,"difficulty_score":109,"env_os":110,"env_gpu":111,"env_ram":111,"env_deps":112,"category_tags":118,"github_topics":119,"view_count":32,"oss_zip_url":76,"oss_zip_packed_at":76,"status":17,"created_at":130,"updated_at":131,"faqs":132,"releases":167},7679,"thrasher-corp\u002Fgocryptotrader","gocryptotrader","A cryptocurrency trading bot and framework supporting multiple exchanges written in Golang.","gocryptotrader 是一款基于 Go 语言开发的开源加密货币交易机器人框架，旨在为开发者提供构建自动化交易策略的坚实基础。它有效解决了手动管理多个交易所账户繁琐、不同平台接口标准不一以及高频交易下系统稳定性难保障等痛点。\n\n该工具主要面向具备一定编程能力的开发者、量化研究员及技术极客。虽然官方提示其仍处于开发阶段，尚未完全适用于生产环境，但其功能已相当丰富。gocryptotrader 的核心亮点在于强大的多交易所支持能力，目前已兼容 Binance、OKX、Kraken 等主流平台的 REST 和 WebSocket 接口，并提供统一的 API 调用方式，极大降低了跨平台开发的复杂度。\n\n此外，它还内置了 AES256 加密配置、HTTP 速率限制、数据库支持（Postgres\u002FSQLite3）、gRPC 服务以及回测应用等专业模块，帮助用户安全高效地管理投资组合、监控市场数据并执行复杂策略。无论是想尝试编写自己的交易算法，还是希望深入研究加密货币市场数据，gocryptotrader 都是一个值得探索的开源选择。","\u003Cimg src=\"https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_93627c9d5388.png\" width=\"350px\" height=\"350px\" hspace=\"70\">\n\n[![Build Status](https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Factions\u002Fworkflows\u002Ftests.yml\u002Fbadge.svg?branch=master)](https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Factions\u002Fworkflows\u002Ftests.yml)\n[![Software License](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FLicense-MIT-orange.svg?style=flat-square)](https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fblob\u002Fmaster\u002FLICENSE)\n[![GoDoc](https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_ff803135673c.png)](https:\u002F\u002Fgodoc.org\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader)\n[![Coverage Status](https:\u002F\u002Fcodecov.io\u002Fgh\u002Fthrasher-corp\u002Fgocryptotrader\u002Fgraph\u002Fbadge.svg?token=41784B23TS)](https:\u002F\u002Fcodecov.io\u002Fgh\u002Fthrasher-corp\u002Fgocryptotrader)\n[![Go Report Card](https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_2b4a70945b89.png)](https:\u002F\u002Fgoreportcard.com\u002Freport\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader)\n\nA cryptocurrency trading bot supporting multiple exchanges written in Golang.\n\n**Please note that this bot is under development and is not ready for production!**\n\n## Community\n\nJoin our slack to discuss all things related to GoCryptoTrader! [GoCryptoTrader Slack](https:\u002F\u002Fjoin.slack.com\u002Ft\u002Fgocryptotrader\u002Fshared_invite\u002Fzt-38z8abs3l-gH8AAOk8XND6DP5NfCiG_g)\n\n## Exchange Support Table\n\n| Exchange | REST API | Websocket API | FIX API |\n|----------|------|-----------|-----|\n| Binance.US| Yes  | Yes        | NA  |\n| Binance| Yes  | Yes        | NA  |\n| Bitfinex | Yes  | Yes        | NA  |\n| Bitflyer | Yes  | No      | NA  |\n| Bithumb | Yes  | Yes       | NA  |\n| BitMEX | Yes | Yes | NA |\n| Bitstamp | Yes  | Yes       | No  |\n| BTCMarkets | Yes | Yes       | NA  |\n| BTSE | Yes | Yes | NA |\n| Bybit | Yes | Yes | NA |\n| Coinbase | Yes | Yes | No|\n| COINUT | Yes | Yes | NA |\n| Deribit | Yes | Yes | No |\n| Exmo | Yes | NA | NA |\n| GateIO | Yes | Yes | NA |\n| Gemini | Yes | Yes | No |\n| HitBTC | Yes | Yes | No |\n| Huobi.Pro | Yes | Yes | NA |\n| Kraken | Yes | Yes | NA |\n| Kucoin | Yes | Yes | NA |\n| Lbank | Yes | No | NA |\n| Okx | Yes | Yes | NA |\n| Poloniex | Yes | Yes | NA |\n| Yobit | Yes | NA | NA |\n\nWe are aiming to support the top 30 exchanges sorted by average liquidity as [ranked by CoinMarketCap](https:\u002F\u002Fcoinmarketcap.com\u002Frankings\u002Fexchanges\u002F). \nHowever, we welcome pull requests for any exchange which does not match this criterion. If you need help with this, please join us on [Slack](https:\u002F\u002Fjoin.slack.com\u002Ft\u002Fgocryptotrader\u002Fshared_invite\u002Fzt-38z8abs3l-gH8AAOk8XND6DP5NfCiG_g).\n\n** NA means not applicable as the exchange does not support the feature.\n\n## Current Features\n\n+ Support for all exchange fiat and digital currencies, with the ability to individually toggle them on\u002Foff.\n+ AES256 encrypted config file.\n+ REST API support for all exchanges.\n+ Websocket support for applicable exchanges.\n+ Ability to turn off\u002Fon certain exchanges.\n+ Communication packages (Slack, SMS via SMSGlobal, Telegram and SMTP).\n+ HTTP rate limiter package.\n+ Unified API for exchange usage.\n+ Customisation of HTTP client features including setting a proxy, user agent and adjusting transport settings.\n+ NTP client package.\n+ Database support (Postgres and SQLite3). See [database](\u002Fdatabase\u002FREADME.md).\n+ OTP generation tool. See [gen otp](\u002Fcmd\u002Fgen_otp).\n+ Connection monitor package.\n+ gRPC service and JSON RPC proxy. See [gRPC service](\u002Fgctrpc\u002FREADME.md).\n+ gRPC client. See [gctcli](\u002Fcmd\u002Fgctcli\u002FREADME.md).\n+ Forex currency converter packages (CurrencyConverterAPI, CurrencyLayer, Exchange Rates, Fixer.io, OpenExchangeRates, Exchange Rate Host).\n+ Packages for handling currency pairs, tickers and orderbooks.\n+ Portfolio management tool; fetches balances from supported exchanges and allows for custom address tracking.\n+ Basic event trigger system.\n+ OHLCV\u002FCandle retrieval support. See [OHLCV](\u002Fdocs\u002FOHLCV.md).\n+ Scripting support. See [gctscript](\u002Fgctscript\u002FREADME.md).\n+ Recent and historic trade processing. See [trades](\u002Fexchanges\u002Ftrade\u002FREADME.md).\n+ Backtesting application. An event-driven backtesting tool to test and iterate trading strategies using historical or custom data. See [backtester](\u002Fbacktester\u002FREADME.md).\n+ Exchange HTTP mock testing. See [mock](\u002Fexchanges\u002Fmock\u002FREADME.md).\n+ Exchange multichain deposits and withdrawals for specific exchanges. See [multichain transfer support](\u002Fdocs\u002FMULTICHAIN_TRANSFER_SUPPORT.md).\n\n## Development Tracking\n\nOur [Kanban board](https:\u002F\u002Fgithub.com\u002Forgs\u002Fthrasher-corp\u002Fprojects\u002F3) provides updates on:\n\n+ New feature development\n+ Bug fixes in progress\n+ Recently completed work\n+ Contribution opportunities\n\nFollow our progress as we continuously improve GoCryptoTrader.\n\n## Contribution\n\nPlease feel free to submit any pull requests or suggest any desired features to be added.\n\nWhen submitting a PR, please abide by our [coding guidelines](\u002Fdocs\u002FCODING_GUIDELINES.md).\n\n## Compiling and Running instructions\n\nDownload and install Go from [Go Downloads](https:\u002F\u002Fgolang.org\u002Fdl\u002F) for your platform.\n\n### Linux\u002FmacOS\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader.git\ncd gocryptotrader\ngo build\nmkdir ~\u002F.gocryptotrader\ncp config_example.json ~\u002F.gocryptotrader\u002Fconfig.json\n```\n\n### Windows\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader.git\ncd gocryptotrader\ngo build\nmkdir %AppData%\\GoCryptoTrader\ncopy config_example.json %APPDATA%\\GoCryptoTrader\\config.json\n```\n\n+ Make any necessary changes to the `config.json` file.\n+ Run the `gocryptotrader` binary file.\n\n### Sonic JSON handling\n\nGoCryptoTrader can optionally use the [Sonic](https:\u002F\u002Fgithub.com\u002Fbytedance\u002Fsonic) JSON library for improved performance, as a drop in replacement for golang.org\u002Fencoding\u002Fjson.\nPlease see sonic [Requirements](https:\u002F\u002Fgithub.com\u002Fbytedance\u002Fsonic\u002F#requirement) for supported platforms.\n\nTo enable sonic, build with the sonic_on tag:\n\n```bash\ngo build -tags=sonic_on\n```\n\n## Donations\n\n\u003Cimg src=\"https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_12aa6eb0c31c.png\" hspace=\"70\">\n\nIf this framework helped you in any way, or you would like to support the developers working on it, please donate Bitcoin to:\n\n***bc1qk0jareu4jytc0cfrhr5wgshsq8282awpavfahc***\n\n## Binaries\n\nBinaries will be published once the codebase reaches a stable condition.\n\n## Contributor List\n\n### A very special thank you to all who have contributed to this program:\n\n|User|Contribution Amount|\n|--|--|\n| [thrasher-](https:\u002F\u002Fgithub.com\u002Fthrasher-) | 737 |\n| [dependabot[bot]](https:\u002F\u002Fgithub.com\u002Fapps\u002Fdependabot) | 415 |\n| [shazbert](https:\u002F\u002Fgithub.com\u002Fshazbert) | 389 |\n| [gloriousCode](https:\u002F\u002Fgithub.com\u002FgloriousCode) | 240 |\n| [gbjk](https:\u002F\u002Fgithub.com\u002Fgbjk) | 143 |\n| [dependabot-preview[bot]](https:\u002F\u002Fgithub.com\u002Fapps\u002Fdependabot-preview) | 88 |\n| [xtda](https:\u002F\u002Fgithub.com\u002Fxtda) | 47 |\n| [lrascao](https:\u002F\u002Fgithub.com\u002Flrascao) | 27 |\n| [Beadko](https:\u002F\u002Fgithub.com\u002FBeadko) | 24 |\n| [samuael](https:\u002F\u002Fgithub.com\u002Fsamuael) | 16 |\n| [vazha](https:\u002F\u002Fgithub.com\u002Fvazha) | 15 |\n| [ydm](https:\u002F\u002Fgithub.com\u002Fydm) | 15 |\n| [Rots](https:\u002F\u002Fgithub.com\u002FRots) | 15 |\n| [ermalguni](https:\u002F\u002Fgithub.com\u002Fermalguni) | 14 |\n| [MadCozBadd](https:\u002F\u002Fgithub.com\u002FMadCozBadd) | 13 |\n| [Copilot](https:\u002F\u002Fgithub.com\u002Fapps\u002Fcopilot-swe-agent) | 13 |\n| [vadimzhukck](https:\u002F\u002Fgithub.com\u002Fvadimzhukck) | 10 |\n| [junnplus](https:\u002F\u002Fgithub.com\u002Fjunnplus) | 9 |\n| [geseq](https:\u002F\u002Fgithub.com\u002Fgeseq) | 8 |\n| [marcofranssen](https:\u002F\u002Fgithub.com\u002Fmarcofranssen) | 8 |\n| [140am](https:\u002F\u002Fgithub.com\u002F140am) | 8 |\n| [cranktakular](https:\u002F\u002Fgithub.com\u002Fcranktakular) | 7 |\n| [TaltaM](https:\u002F\u002Fgithub.com\u002FTaltaM) | 6 |\n| [dackroyd](https:\u002F\u002Fgithub.com\u002Fdackroyd) | 5 |\n| [khcchiu](https:\u002F\u002Fgithub.com\u002Fkhcchiu) | 5 |\n| [yangrq1018](https:\u002F\u002Fgithub.com\u002Fyangrq1018) | 4 |\n| [woshidama323](https:\u002F\u002Fgithub.com\u002Fwoshidama323) | 3 |\n| [romanornr](https:\u002F\u002Fgithub.com\u002Fromanornr) | 3 |\n| [crackcomm](https:\u002F\u002Fgithub.com\u002Fcrackcomm) | 3 |\n| [azhang](https:\u002F\u002Fgithub.com\u002Fazhang) | 2 |\n| [if1live](https:\u002F\u002Fgithub.com\u002Fif1live) | 2 |\n| [lozdog245](https:\u002F\u002Fgithub.com\u002Flozdog245) | 2 |\n| [Asalei](https:\u002F\u002Fgithub.com\u002FAsalei) | 2 |\n| [soxipy](https:\u002F\u002Fgithub.com\u002Fsoxipy) | 2 |\n| [tk42](https:\u002F\u002Fgithub.com\u002Ftk42) | 2 |\n| [herenow](https:\u002F\u002Fgithub.com\u002Fherenow) | 2 |\n| [mshogin](https:\u002F\u002Fgithub.com\u002Fmshogin) | 2 |\n| [andreygrehov](https:\u002F\u002Fgithub.com\u002Fandreygrehov) | 2 |\n| [bretep](https:\u002F\u002Fgithub.com\u002Fbretep) | 2 |\n| [Christian-Achilli](https:\u002F\u002Fgithub.com\u002FChristian-Achilli) | 2 |\n| [dsinuela-taurus](https:\u002F\u002Fgithub.com\u002Fdsinuela-taurus) | 2 |\n| [cornelk](https:\u002F\u002Fgithub.com\u002Fcornelk) | 2 |\n| [gam-phon](https:\u002F\u002Fgithub.com\u002Fgam-phon) | 2 |\n| [MarkDzulko](https:\u002F\u002Fgithub.com\u002FMarkDzulko) | 2 |\n| [MathieuCesbron](https:\u002F\u002Fgithub.com\u002FMathieuCesbron) | 2 |\n| [aidan-bailey](https:\u002F\u002Fgithub.com\u002Faidan-bailey) | 1 |\n| [tongxiaofeng](https:\u002F\u002Fgithub.com\u002Ftongxiaofeng) | 1 |\n| [tonywangcn](https:\u002F\u002Fgithub.com\u002Ftonywangcn) | 1 |\n| [varunbhat](https:\u002F\u002Fgithub.com\u002Fvarunbhat) | 1 |\n| [idealhack](https:\u002F\u002Fgithub.com\u002Fidealhack) | 1 |\n| [hannut91](https:\u002F\u002Fgithub.com\u002Fhannut91) | 1 |\n| [vyloy](https:\u002F\u002Fgithub.com\u002Fvyloy) | 1 |\n| [arttobe](https:\u002F\u002Fgithub.com\u002Farttobe) | 1 |\n| [shoman4eg](https:\u002F\u002Fgithub.com\u002Fshoman4eg) | 1 |\n| [cangqiaoyuzhuo](https:\u002F\u002Fgithub.com\u002Fcangqiaoyuzhuo) | 1 |\n| [dazi005](https:\u002F\u002Fgithub.com\u002Fdazi005) | 1 |\n| [gcmutator](https:\u002F\u002Fgithub.com\u002Fgcmutator) | 1 |\n| [gopherorg](https:\u002F\u002Fgithub.com\u002Fgopherorg) | 1 |\n| [whilei](https:\u002F\u002Fgithub.com\u002Fwhilei) | 1 |\n| [yuhangcangqian](https:\u002F\u002Fgithub.com\u002Fyuhangcangqian) | 1 |\n| [keeghcet](https:\u002F\u002Fgithub.com\u002Fkeeghcet) | 1 |\n| [mickychang9](https:\u002F\u002Fgithub.com\u002Fmickychang9) | 1 |\n| [phieudu241](https:\u002F\u002Fgithub.com\u002Fphieudu241) | 1 |\n| [quantpoet](https:\u002F\u002Fgithub.com\u002Fquantpoet) | 1 |\n| [snipesjr](https:\u002F\u002Fgithub.com\u002Fsnipesjr) | 1 |\n| [snussik](https:\u002F\u002Fgithub.com\u002Fsnussik) | 1 |\n| [taewdy](https:\u002F\u002Fgithub.com\u002Ftaewdy) | 1 |\n| [threehonor](https:\u002F\u002Fgithub.com\u002Fthreehonor) | 1 |\n| [xiiiew](https:\u002F\u002Fgithub.com\u002Fxiiiew) | 1 |\n| [youzichuan](https:\u002F\u002Fgithub.com\u002Fyouzichuan) | 1 |\n| [antonzhukov](https:\u002F\u002Fgithub.com\u002Fantonzhukov) | 1 |\n| [blombard](https:\u002F\u002Fgithub.com\u002Fblombard) | 1 |\n| [CodeLingoBot](https:\u002F\u002Fgithub.com\u002FCodeLingoBot) | 1 |\n| [CodeLingoTeam](https:\u002F\u002Fgithub.com\u002FCodeLingoTeam) | 1 |\n| [Daanikus](https:\u002F\u002Fgithub.com\u002FDaanikus) | 1 |\n| [daniel-cohen-deltatre](https:\u002F\u002Fgithub.com\u002Fdaniel-cohen-deltatre) | 1 |\n| [merkeld](https:\u002F\u002Fgithub.com\u002Fmerkeld) | 1 |\n| [shanhuhai5739](https:\u002F\u002Fgithub.com\u002Fshanhuhai5739) | 1 |\n| [DirectX](https:\u002F\u002Fgithub.com\u002FDirectX) | 1 |\n| [dnldd](https:\u002F\u002Fgithub.com\u002Fdnldd) | 1 |\n| [Juneezee](https:\u002F\u002Fgithub.com\u002FJuneezee) | 1 |\n| [fclairamb](https:\u002F\u002Fgithub.com\u002Ffclairamb) | 1 |\n| [frankzougc](https:\u002F\u002Fgithub.com\u002Ffrankzougc) | 1 |\n| [gemscng](https:\u002F\u002Fgithub.com\u002Fgemscng) | 1 |\n| [Jdpurohit](https:\u002F\u002Fgithub.com\u002FJdpurohit) | 1 |\n| [jimexist](https:\u002F\u002Fgithub.com\u002Fjimexist) | 1 |\n| [lookfirst](https:\u002F\u002Fgithub.com\u002Flookfirst) | 1 |\n| [zeldrinn](https:\u002F\u002Fgithub.com\u002Fzeldrinn) | 1 |\n| [roskee](https:\u002F\u002Fgithub.com\u002Froskee) | 1 |\n| [mattkanwisher](https:\u002F\u002Fgithub.com\u002Fmattkanwisher) | 1 |\n| [mgravitt](https:\u002F\u002Fgithub.com\u002Fmgravitt) | 1 |\n| [mKurrels](https:\u002F\u002Fgithub.com\u002FmKurrels) | 1 |\n| [m1kola](https:\u002F\u002Fgithub.com\u002Fm1kola) | 1 |\n| [mortensorensen](https:\u002F\u002Fgithub.com\u002Fmortensorensen) | 1 |\n| [Polizo96](https:\u002F\u002Fgithub.com\u002FPolizo96) | 1 |\n| [cavapoo2](https:\u002F\u002Fgithub.com\u002Fcavapoo2) | 1 |\n| [idoall](https:\u002F\u002Fgithub.com\u002Fidoall) | 1 |\n| [starit](https:\u002F\u002Fgithub.com\u002Fstarit) | 1 |\n","\u003Cimg src=\"https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_93627c9d5388.png\" width=\"350px\" height=\"350px\" hspace=\"70\">\n\n[![构建状态](https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Factions\u002Fworkflows\u002Ftests.yml\u002Fbadge.svg?branch=master)](https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Factions\u002Fworkflows\u002Ftests.yml)\n[![软件许可](https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FLicense-MIT-orange.svg?style=flat-square)](https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fblob\u002Fmaster\u002FLICENSE)\n[![GoDoc](https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_ff803135673c.png)](https:\u002F\u002Fgodoc.org\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader)\n[![覆盖率](https:\u002F\u002Fcodecov.io\u002Fgh\u002Fthrasher-corp\u002Fgocryptotrader\u002Fgraph\u002Fbadge.svg?token=41784B23TS)](https:\u002F\u002Fcodecov.io\u002Fgh\u002Fthrasher-corp\u002Fgocryptotrader)\n[![Go报告卡](https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_2b4a70945b89.png)](https:\u002F\u002Fgoreportcard.com\u002Freport\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader)\n\n一款用Golang编写的、支持多个交易所的加密货币交易机器人。\n\n**请注意，此机器人仍在开发中，尚未准备好投入生产使用！**\n\n## 社区\n\n加入我们的Slack频道，讨论与GoCryptoTrader相关的一切话题！ [GoCryptoTrader Slack](https:\u002F\u002Fjoin.slack.com\u002Ft\u002Fgocryptotrader\u002Fshared_invite\u002Fzt-38z8abs3l-gH8AAOk8XND6DP5NfCiG_g)\n\n## 交易所支持表\n\n| 交易所 | REST API | WebSocket API | FIX API |\n|----------|------|-----------|-----|\n| Binance.US| 是  | 是        | 不适用  |\n| Binance| 是  | 是        | 不适用  |\n| Bitfinex | 是  | 是        | 不适用  |\n| Bitflyer | 是  | 否      | 不适用  |\n| Bithumb | 是  | 是       | 不适用  |\n| BitMEX | 是 | 是 | 不适用 |\n| Bitstamp | 是  | 是       | 否  |\n| BTCMarkets | 是 | 是       | 不适用  |\n| BTSE | 是 | 是 | 不适用 |\n| Bybit | 是 | 是 | 不适用 |\n| Coinbase | 是 | 是 | 否|\n| COINUT | 是 | 是 | 不适用 |\n| Deribit | 是 | 是 | 否 |\n| Exmo | 是 | 不适用 | 不适用 |\n| GateIO | 是 | 是 | 不适用 |\n| Gemini | 是 | 是 | 否 |\n| HitBTC | 是 | 是 | 否 |\n| Huobi.Pro | 是 | 是 | 不适用 |\n| Kraken | 是 | 是 | 不适用 |\n| Kucoin | 是 | 是 | 不适用 |\n| Lbank | 是 | 否 | 不适用 |\n| Okx | 是 | 是 | 不适用 |\n| Poloniex | 是 | 是 | 不适用 |\n| Yobit | 是 | 不适用 | 不适用 |\n\n我们的目标是支持按平均流动性排序的前30家交易所，如[CoinMarketCap排名](https:\u002F\u002Fcoinmarketcap.com\u002Frankings\u002Fexchanges\u002F)所示。不过，我们也欢迎针对不符合这一标准的任何交易所提交的拉取请求。如果您需要帮助，请加入我们的[Slack](https:\u002F\u002Fjoin.slack.com\u002Ft\u002Fgocryptotrader\u002Fshared_invite\u002Fzt-38z8abs3l-gH8AAOk8XND6DP5NfCiG_g)。\n\n**“不适用”表示该交易所不支持相应功能。**\n\n## 当前功能\n\n+ 支持所有交易所的法币和数字货币，并可单独开启或关闭。\n+ AES256加密配置文件。\n+ 所有交易所的REST API支持。\n+ 适用交易所的WebSocket支持。\n+ 可以启用或禁用特定交易所。\n+ 通信模块（Slack、通过SMSGlobal发送短信、Telegram和SMTP）。\n+ HTTP限流器模块。\n+ 统一的交易所API。\n+ 自定义HTTP客户端功能，包括设置代理、用户代理以及调整传输设置。\n+ NTP客户端模块。\n+ 数据库支持（Postgres和SQLite3）。详情请参阅[数据库](\u002Fdatabase\u002FREADME.md)。\n+ OTP生成工具。详情请参阅[gen otp](\u002Fcmd\u002Fgen_otp)。\n+ 连接监控模块。\n+ gRPC服务和JSON RPC代理。详情请参阅[gRPC服务](\u002Fgctrpc\u002FREADME.md)。\n+ gRPC客户端。详情请参阅[gctcli](\u002Fcmd\u002Fgctcli\u002FREADME.md)。\n+ 外汇货币转换模块（CurrencyConverterAPI、CurrencyLayer、Exchange Rates、Fixer.io、OpenExchangeRates、Exchange Rate Host）。\n+ 处理货币对、行情和订单簿的模块。\n+ 投资组合管理工具；从支持的交易所获取余额，并允许自定义地址跟踪。\n+ 基本事件触发系统。\n+ OHLCV\u002F蜡烛图获取支持。详情请参阅[OHLCV](\u002Fdocs\u002FOHLCV.md)。\n+ 脚本支持。详情请参阅[gctscript](\u002Fgctscript\u002FREADME.md)。\n+ 最近及历史交易处理。详情请参阅[trades](\u002Fexchanges\u002Ftrade\u002FREADME.md)。\n+ 回测应用。一个基于事件驱动的回测工具，可用于利用历史或自定义数据测试和迭代交易策略。详情请参阅[backtester](\u002Fbacktester\u002FREADME.md)。\n+ 交易所HTTP模拟测试。详情请参阅[mock](\u002Fexchanges\u002Fmock\u002FREADME.md)。\n+ 针对特定交易所的多链存取款支持。详情请参阅[多链转账支持](\u002Fdocs\u002FMULTICHAIN_TRANSFER_SUPPORT.md)。\n\n## 开发进度追踪\n\n我们的[Kanban看板](https:\u002F\u002Fgithub.com\u002Forgs\u002Fthrasher-corp\u002Fprojects\u002F3)会提供以下信息的更新：\n\n+ 新功能开发\n+ 正在进行的bug修复\n+ 最近完成的工作\n+ 贡献机会\n\n请关注我们的进展，我们将不断改进GoCryptoTrader。\n\n## 贡献\n\n欢迎您随时提交任何拉取请求或建议添加的功能。\n\n在提交PR时，请遵守我们的[编码规范](\u002Fdocs\u002FCODING_GUIDELINES.md)。\n\n## 编译与运行说明\n\n请根据您的平台从[Go下载页面](https:\u002F\u002Fgolang.org\u002Fdl\u002F)下载并安装Go。\n\n### Linux\u002FmacOS\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader.git\ncd gocryptotrader\ngo build\nmkdir ~\u002F.gocryptotrader\ncp config_example.json ~\u002F.gocryptotrader\u002Fconfig.json\n```\n\n### Windows\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader.git\ncd gocryptotrader\ngo build\nmkdir %AppData%\\GoCryptoTrader\ncopy config_example.json %APPDATA%\\GoCryptoTrader\\config.json\n```\n\n+ 对`config.json`文件进行必要的修改。\n+ 运行`gocryptotrader`二进制文件。\n\n### Sonic JSON处理\n\nGoCryptoTrader可以选择使用[Sonic](https:\u002F\u002Fgithub.com\u002Fbytedance\u002Fsonic) JSON库来提升性能，作为golang.org\u002Fencoding\u002Fjson的直接替代品。\n请参阅sonic的[要求](https:\u002F\u002Fgithub.com\u002Fbytedance\u002Fsonic\u002F#requirement)，了解支持的平台。\n\n要启用Sonic，可以使用sonic_on标签进行构建：\n\n```bash\ngo build -tags=sonic_on\n```\n\n## 捐赠\n\n\u003Cimg src=\"https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_readme_12aa6eb0c31c.png\" hspace=\"70\">\n\n如果这个框架对您有所帮助，或者您希望支持正在开发它的开发者，请捐赠比特币至：\n\n***bc1qk0jareu4jytc0cfrhr5wgshsq8282awpavfahc***\n\n## 二进制文件\n\n二进制文件将在代码库达到稳定状态后发布。\n\n## 贡献者列表\n\n### 向所有为本项目做出贡献的朋友们致以最诚挚的感谢：\n\n|用户|捐款金额|\n|--|--|\n| [thrasher-](https:\u002F\u002Fgithub.com\u002Fthrasher-) | 737 |\n| [dependabot[bot]](https:\u002F\u002Fgithub.com\u002Fapps\u002Fdependabot) | 415 |\n| [shazbert](https:\u002F\u002Fgithub.com\u002Fshazbert) | 389 |\n| [gloriousCode](https:\u002F\u002Fgithub.com\u002FgloriousCode) | 240 |\n| [gbjk](https:\u002F\u002Fgithub.com\u002Fgbjk) | 143 |\n| [dependabot-preview[bot]](https:\u002F\u002Fgithub.com\u002Fapps\u002Fdependabot-preview) | 88 |\n| [xtda](https:\u002F\u002Fgithub.com\u002Fxtda) | 47 |\n| [lrascao](https:\u002F\u002Fgithub.com\u002Flrascao) | 27 |\n| [Beadko](https:\u002F\u002Fgithub.com\u002FBeadko) | 24 |\n| [samuael](https:\u002F\u002Fgithub.com\u002Fsamuael) | 16 |\n| [vazha](https:\u002F\u002Fgithub.com\u002Fvazha) | 15 |\n| [ydm](https:\u002F\u002Fgithub.com\u002Fydm) | 15 |\n| [Rots](https:\u002F\u002Fgithub.com\u002FRots) | 15 |\n| [ermalguni](https:\u002F\u002Fgithub.com\u002Fermalguni) | 14 |\n| [MadCozBadd](https:\u002F\u002Fgithub.com\u002FMadCozBadd) | 13 |\n| [Copilot](https:\u002F\u002Fgithub.com\u002Fapps\u002Fcopilot-swe-agent) | 13 |\n| [vadimzhukck](https:\u002F\u002Fgithub.com\u002Fvadimzhukck) | 10 |\n| [junnplus](https:\u002F\u002Fgithub.com\u002Fjunnplus) | 9 |\n| [geseq](https:\u002F\u002Fgithub.com\u002Fgeseq) | 8 |\n| [marcofranssen](https:\u002F\u002Fgithub.com\u002Fmarcofranssen) | 8 |\n| [140am](https:\u002F\u002Fgithub.com\u002F140am) | 8 |\n| [cranktakular](https:\u002F\u002Fgithub.com\u002Fcranktakular) | 7 |\n| [TaltaM](https:\u002F\u002Fgithub.com\u002FTaltaM) | 6 |\n| [dackroyd](https:\u002F\u002Fgithub.com\u002Fdackroyd) | 5 |\n| [khcchiu](https:\u002F\u002Fgithub.com\u002Fkhcchiu) | 5 |\n| [yangrq1018](https:\u002F\u002Fgithub.com\u002Fyangrq1018) | 4 |\n| [woshidama323](https:\u002F\u002Fgithub.com\u002Fwoshidama323) | 3 |\n| [romanornr](https:\u002F\u002Fgithub.com\u002Fromanornr) | 3 |\n| [crackcomm](https:\u002F\u002Fgithub.com\u002Fcrackcomm) | 3 |\n| [azhang](https:\u002F\u002Fgithub.com\u002Fazhang) | 2 |\n| [if1live](https:\u002F\u002Fgithub.com\u002Fif1live) | 2 |\n| [lozdog245](https:\u002F\u002Fgithub.com\u002Flozdog245) | 2 |\n| [Asalei](https:\u002F\u002Fgithub.com\u002FAsalei) | 2 |\n| [soxipy](https:\u002F\u002Fgithub.com\u002Fsoxipy) | 2 |\n| [tk42](https:\u002F\u002Fgithub.com\u002Ftk42) | 2 |\n| [herenow](https:\u002F\u002Fgithub.com\u002Fherenow) | 2 |\n| [mshogin](https:\u002F\u002Fgithub.com\u002Fmshogin) | 2 |\n| [andreygrehov](https:\u002F\u002Fgithub.com\u002Fandreygrehov) | 2 |\n| [bretep](https:\u002F\u002Fgithub.com\u002Fbretep) | 2 |\n| [Christian-Achilli](https:\u002F\u002Fgithub.com\u002FChristian-Achilli) | 2 |\n| [dsinuela-taurus](https:\u002F\u002Fgithub.com\u002Fdsinuela-taurus) | 2 |\n| [cornelk](https:\u002F\u002Fgithub.com\u002Fcornelk) | 2 |\n| [gam-phon](https:\u002F\u002Fgithub.com\u002Fgam-phon) | 2 |\n| [MarkDzulko](https:\u002F\u002Fgithub.com\u002FMarkDzulko) | 2 |\n| [MathieuCesbron](https:\u002F\u002Fgithub.com\u002FMathieuCesbron) | 2 |\n| [aidan-bailey](https:\u002F\u002Fgithub.com\u002Faidan-bailey) | 1 |\n| [tongxiaofeng](https:\u002F\u002Fgithub.com\u002Ftongxiaofeng) | 1 |\n| [tonywangcn](https:\u002F\u002Fgithub.com\u002Ftonywangcn) | 1 |\n| [varunbhat](https:\u002F\u002Fgithub.com\u002Fvarunbhat) | 1 |\n| [idealhack](https:\u002F\u002Fgithub.com\u002Fidealhack) | 1 |\n| [hannut91](https:\u002F\u002Fgithub.com\u002Fhannut91) | 1 |\n| [vyloy](https:\u002F\u002Fgithub.com\u002Fvyloy) | 1 |\n| [arttobe](https:\u002F\u002Fgithub.com\u002Farttobe) | 1 |\n| [shoman4eg](https:\u002F\u002Fgithub.com\u002Fshoman4eg) | 1 |\n| [cangqiaoyuzhuo](https:\u002F\u002Fgithub.com\u002Fcangqiaoyuzhuo) | 1 |\n| [dazi005](https:\u002F\u002Fgithub.com\u002Fdazi005) | 1 |\n| [gcmutator](https:\u002F\u002Fgithub.com\u002Fgcmutator) | 1 |\n| [gopherorg](https:\u002F\u002Fgithub.com\u002Fgopherorg) | 1 |\n| [whilei](https:\u002F\u002Fgithub.com\u002Fwhilei) | 1 |\n| [yuhangcangqian](https:\u002F\u002Fgithub.com\u002Fyuhangcangqian) | 1 |\n| [keeghcet](https:\u002F\u002Fgithub.com\u002Fkeeghcet) | 1 |\n| [mickychang9](https:\u002F\u002Fgithub.com\u002Fmickychang9) | 1 |\n| [phieudu241](https:\u002F\u002Fgithub.com\u002Fphieudu241) | 1 |\n| [quantpoet](https:\u002F\u002Fgithub.com\u002Fquantpoet) | 1 |\n| [snipesjr](https:\u002F\u002Fgithub.com\u002Fsnipesjr) | 1 |\n| [snussik](https:\u002F\u002Fgithub.com\u002Fsnussik) | 1 |\n| [taewdy](https:\u002F\u002Fgithub.com\u002Ftaewdy) | 1 |\n| [threehonor](https:\u002F\u002Fgithub.com\u002Fthreehonor) | 1 |\n| [xiiiew](https:\u002F\u002Fgithub.com\u002Fxiiiew) | 1 |\n| [youzichuan](https:\u002F\u002Fgithub.com\u002Fyouzichuan) | 1 |\n| [antonzhukov](https:\u002F\u002Fgithub.com\u002Fantonzhukov) | 1 |\n| [blombard](https:\u002F\u002Fgithub.com\u002Fblombard) | 1 |\n| [CodeLingoBot](https:\u002F\u002Fgithub.com\u002FCodeLingoBot) | 1 |\n| [CodeLingoTeam](https:\u002F\u002Fgithub.com\u002FCodeLingoTeam) | 1 |\n| [Daanikus](https:\u002F\u002Fgithub.com\u002FDaanikus) | 1 |\n| [daniel-cohen-deltatre](https:\u002F\u002Fgithub.com\u002Fdaniel-cohen-deltatre) | 1 |\n| [merkeld](https:\u002F\u002Fgithub.com\u002Fmerkeld) | 1 |\n| [shanhuhai5739](https:\u002F\u002Fgithub.com\u002Fshanhuhai5739) | 1 |\n| [DirectX](https:\u002F\u002Fgithub.com\u002FDirectX) | 1 |\n| [dnldd](https:\u002F\u002Fgithub.com\u002Fdnldd) | 1 |\n| [Juneezee](https:\u002F\u002Fgithub.com\u002FJuneezee) | 1 |\n| [fclairamb](https:\u002F\u002Fgithub.com\u002Ffclairamb) | 1 |\n| [frankzougc](https:\u002F\u002Fgithub.com\u002Ffrankzougc) | 1 |\n| [gemscng](https:\u002F\u002Fgithub.com\u002Fgemscng) | 1 |\n| [Jdpurohit](https:\u002F\u002Fgithub.com\u002FJdpurohit) | 1 |\n| [jimexist](https:\u002F\u002Fgithub.com\u002Fjimexist) | 1 |\n| [lookfirst](https:\u002F\u002Fgithub.com\u002Flookfirst) | 1 |\n| [zeldrinn](https:\u002F\u002Fgithub.com\u002Fzeldrinn) | 1 |\n| [roskee](https:\u002F\u002Fgithub.com\u002Froskee) | 1 |\n| [mattkanwisher](https:\u002F\u002Fgithub.com\u002Fmattkanwisher) | 1 |\n| [mgravitt](https:\u002F\u002Fgithub.com\u002Fmgravitt) | 1 |\n| [mKurrels](https:\u002F\u002Fgithub.com\u002FmKurrels) | 1 |\n| [m1kola](https:\u002F\u002Fgithub.com\u002Fm1kola) | 1 |\n| [mortensorensen](https:\u002F\u002Fgithub.com\u002Fmortensorensen) | 1 |\n| [Polizo96](https:\u002F\u002Fgithub.com\u002FPolizo96) | 1 |\n| [cavapoo2](https:\u002F\u002Fgithub.com\u002Fcavapoo2) | 1 |\n| [idoall](https:\u002F\u002Fgithub.com\u002Fidoall) | 1 |\n| [starit](https:\u002F\u002Fgithub.com\u002Fstarit) | 1 |","# GoCryptoTrader 快速上手指南\n\nGoCryptoTrader 是一个用 Golang 编写的支持多交易所的加密货币交易机器人框架。**注意：该项目仍在开发中，尚未达到生产环境就绪状态。**\n\n## 环境准备\n\n### 系统要求\n- **操作系统**: Linux, macOS, 或 Windows\n- **Go 语言版本**: 需安装较新版本的 Go (建议 1.18+)\n\n### 前置依赖\n1. **安装 Go**: 访问 [Go 下载页面](https:\u002F\u002Fgolang.org\u002Fdl\u002F) 下载并安装适合你平台的版本。\n   - *国内用户加速*: 可设置环境变量使用国内镜像源加速模块下载：\n     ```bash\n     export GOPROXY=https:\u002F\u002Fgoproxy.cn,direct\n     ```\n2. **Git**: 确保系统已安装 Git 用于克隆代码库。\n\n## 安装步骤\n\n### 1. 克隆项目代码\n在终端执行以下命令：\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader.git\ncd gocryptotrader\n```\n\n### 2. 编译项目\n根据操作系统选择对应的构建命令：\n\n**Linux \u002F macOS:**\n```bash\ngo build\nmkdir ~\u002F.gocryptotrader\ncp config_example.json ~\u002F.gocryptotrader\u002Fconfig.json\n```\n\n**Windows (PowerShell\u002FCMD):**\n```bash\ngo build\nmkdir %AppData%\\GoCryptoTrader\ncopy config_example.json %APPDATA%\\GoCryptoTrader\\config.json\n```\n\n*(可选) 高性能模式*: 如果你的平台支持，可以使用 `Sonic` JSON 库提升性能：\n```bash\ngo build -tags=sonic_on\n```\n\n### 3. 配置文件初始化\n编译完成后，你需要编辑生成的配置文件以启用交易所和设置 API 密钥：\n- **Linux\u002FmacOS**: `~\u002F.gocryptotrader\u002Fconfig.json`\n- **Windows**: `%APPDATA%\\GoCryptoTrader\\config.json`\n\n请在配置文件中填写对应交易所的 API Key 和 Secret，并根据需要开启\u002F关闭特定交易所支持。\n\n## 基本使用\n\n### 启动机器人\n完成配置后，直接运行二进制文件即可启动：\n\n**Linux \u002F macOS:**\n```bash\n.\u002Fgocryptotrader\n```\n\n**Windows:**\n```bash\ngocryptotrader.exe\n```\n\n### 验证运行\n启动成功后，程序将加载配置的交易所连接（REST API 和 Websocket），并开始同步市场数据、订单簿及账户余额信息。你可以通过查看控制台日志确认连接状态。\n\n### 进阶功能入口\n- **命令行工具**: 使用 `gctcli` (需单独编译 `cmd\u002Fgctcli`) 通过 gRPC 与运行的实例交互。\n- **脚本支持**: 参考 `gctscript` 模块编写自动化交易策略。\n- **回测系统**: 使用 `backtester` 模块基于历史数据测试策略。\n\n> **提示**: 具体配置项详解、API 文档及脚本编写指南请参阅项目根目录下的详细文档或 Godoc。","一位量化交易开发者试图在币安、OKX 和 Kraken 三个交易所同时运行一套复杂的套利策略，并需要实时接收行情数据以执行毫秒级下单。\n\n### 没有 gocryptotrader 时\n- **重复造轮子**：必须分别为三家交易所编写独立的 API 对接代码，处理各自不同的鉴权机制、参数格式和错误码，开发周期长达数周。\n- **数据源割裂**：难以统一维护多个 WebSocket 连接，一旦某个交易所接口变动或断连，缺乏统一的监控和自动重连机制，导致策略中断。\n- **运维风险高**：配置文件明文存储 API 密钥，存在泄露隐患；且缺乏内置的 HTTP 频率限制器，极易因请求过快触发交易所封禁。\n- **回测困难**：历史 K 线（OHLCV）和成交数据分散在不同格式的文件中，清洗和对齐数据耗费大量精力，无法快速验证策略有效性。\n\n### 使用 gocryptotrader 后\n- **统一开发体验**：利用 gocryptotrader 提供的统一 API 抽象层，只需编写一次策略逻辑即可无缝部署到所有支持的交易所，开发时间缩短至几天。\n- **稳定数据流**：内置的 WebSocket 管理模块自动处理多交易所的行情订阅、断线重连及心跳检测，确保策略 7x24 小时稳定运行。\n- **安全与合规**：通过 AES256 加密配置文件保护密钥，并启用内置的 HTTP 速率限制包，自动规避交易所的频率限制规则。\n- **高效回测迭代**：直接调用内置的 OHLCV 获取工具和回测应用，快速拉取并对齐多交易所历史数据，当天即可完成策略验证与优化。\n\ngocryptotrader 将繁琐的交易所底层对接工作标准化，让开发者能专注于核心交易策略的实现与盈利。","https:\u002F\u002Foss.gittoolsai.com\u002Fimages\u002Fthrasher-corp_gocryptotrader_93627c9d.png","thrasher-corp","THRASHER CORPORATION","https:\u002F\u002Foss.gittoolsai.com\u002Favatars\u002Fthrasher-corp_371eca09.png","",null,"contact@thrasher.io","https:\u002F\u002Fwww.thrasher.io","https:\u002F\u002Fgithub.com\u002Fthrasher-corp",[81,85,88,92,96,99,102],{"name":82,"color":83,"percentage":84},"Go","#00ADD8",99,{"name":86,"color":83,"percentage":87},"Go Template",0.9,{"name":89,"color":90,"percentage":91},"Shell","#89e051",0.1,{"name":93,"color":94,"percentage":95},"Makefile","#427819",0,{"name":97,"color":98,"percentage":95},"Dockerfile","#384d54",{"name":100,"color":101,"percentage":95},"PowerShell","#012456",{"name":103,"color":104,"percentage":95},"Batchfile","#C1F12E",3419,902,"2026-04-13T06:13:07","MIT",4,"Linux, macOS, Windows","未说明",{"notes":113,"python":114,"dependencies":115},"该项目使用 Go 语言编写，非 Python 项目。需安装 Go 环境并手动编译源码运行。支持可选的 Sonic JSON 库以提升性能（需使用 'sonic_on' 标签编译）。配置文件需从示例文件复制并修改。目前处于开发阶段，尚未准备好用于生产环境。支持 PostgreSQL 和 SQLite3 数据库。","不适用 (基于 Go 语言)",[116,117],"Go (最新稳定版)","Sonic JSON (可选，需特定平台)",[14],[120,121,122,123,124,125,126,127,128,129],"cryptocurrency","trading-bot","trading-platform","golang","exchange","go","cryptocurrency-trading-bot","trading-framework","algorithmic-trading","algorithmic-trading-library","2026-03-27T02:49:30.150509","2026-04-15T13:05:06.396135",[133,138,143,148,153,158,163],{"id":134,"question_zh":135,"answer_zh":136,"source_url":137},34382,"遇到“并发写入 websocket 连接”导致程序崩溃（panic）怎么办？","该问题通常由多个 goroutine 同时尝试写入同一个 websocket 连接引起。维护者表示已在最新的 master 分支中修复了此问题。如果遇到此错误，请拉取最新代码并重新编译运行：`git pull origin master` 然后重新构建项目。如果问题依旧存在，请提供复现步骤以便进一步调查。","https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fissues\u002F119",{"id":139,"question_zh":140,"answer_zh":141,"source_url":142},34383,"OKX 交易所的 Websocket 无法建立连接或报错怎么办？","这通常是由于配置文件 `config.json` 中的订阅设置与当前版本不兼容导致的。请检查配置文件中 OKX 的 `subscriptions` 部分。如果之前手动配置了具体的 channel（如 ticker, allTrades 等）导致报错，可以尝试移除这些特定的子配置项，让系统使用默认设置，或者确保配置的 channel 名称和参数完全符合当前版本的规范。删除冲突的配置后通常即可正常连接。","https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fissues\u002F1721",{"id":144,"question_zh":145,"answer_zh":146,"source_url":147},34384,"Coinbase Pro 提交订单时返回\"request timestamp expired\"错误如何解决？","该错误通常是由于本地时间与服务器时间不同步，或者生成时间戳的方式不正确导致的。解决方案是将生成 `CB-ACCESS-TIMESTAMP` 的逻辑修改为使用 `strconv.FormatInt(time.Now().Unix(), 10)` 来直接获取当前的 Unix 时间戳，而不是使用 nonce 或其他不稳定的值。此外，建议在服务器上启用并配置 NTP 客户端以确保系统时间精确同步。","https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fissues\u002F440",{"id":149,"question_zh":150,"answer_zh":151,"source_url":152},34385,"连接 Binance Websocket 时出现\"connection reset by peer\"错误怎么办？","这通常是由于网络环境问题（如 DNS 污染或防火墙限制）导致的，特别是在某些地区无法直接访问 Binance 的 Spot WS 接口。解决方案包括：1. 尝试更换代理服务器（Proxy）进行连接；2. 检查 DNS 设置是否被污染；3. 使用工具如 `websocat` 测试连接：`websocat --socks5 127.0.0.1:5750 'wss:\u002F\u002Fstream.binance.com:9443\u002Fws\u002Fbtcusdt@kline_1m' -v`。如果期货接口正常而现货接口失败，大概率是网络链路问题，配置代理通常能解决。","https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fissues\u002F710",{"id":154,"question_zh":155,"answer_zh":156,"source_url":157},34386,"如何正确安装和运行 GoCryptoTrader？遇到 panic 或 Docker 错误怎么办？","安装步骤如下：1. 使用 `go get github.com\u002Fthrasher-\u002Fgocryptotrader` 获取代码；2. 进入目录执行 `go install`；3. 将示例配置文件复制为正式配置：`cp config_example.dat config.dat`（注意文件名通常为 config.dat 而非 config.da）；4. 运行 `.\u002Fgocryptotrader`。如果遇到 panic，请检查 `config.dat` 文件，确保在第 50 行左右启用了 Webserver（设置为 true）。关于 Docker 错误，由于官方对 Docker 支持有限且 Dockerfile 可能缺失或不更新，建议优先使用本地 Go 环境运行，或自行根据项目结构编写 Dockerfile。","https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fissues\u002F61",{"id":159,"question_zh":160,"answer_zh":161,"source_url":162},34387,"GoCryptoTrader 是否支持 KuCoin 和 KuMEX 交易所？","是的，GoCryptoTrader 已经支持 KuCoin 交易所。之前的 KuMEX 交易所已被 KuCoin 合并并重塑为其主合约平台，相关功能也已整合进 KuCoin 的支持模块中。用户可以在配置文件中启用 KuCoin 即可使用相关的现货及合约交易功能。","https:\u002F\u002Fgithub.com\u002Fthrasher-corp\u002Fgocryptotrader\u002Fissues\u002F410",{"id":164,"question_zh":165,"answer_zh":166,"source_url":142},34388,"GCT 和 gctcli 有什么区别？","`GCT` (GoCryptoTrader) 指的是主要的守护进程应用程序（daemon application），负责核心的交易逻辑、数据收集和交易所连接。而 `gctcli` 是一个命令行工具（CLI tool），用于通过 gRPC 协议与正在运行的 GCT 守护进程进行交互，执行查询状态、下达指令等操作。使用时需先启动 GCT 主程序，再通过 gctcli 进行控制。",[]]