﻿<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/css' href='https://stocksharp.ru/css/style.css'?>
<?xml-stylesheet type='text/css' href='https://stocksharp.ru/css/bbeditor.css'?>
<feed xmlns="http://www.w3.org/2005/Atom">
  <title type="html">Как мы с помощью ИИ пишем коннекторы к криптобиржам</title>
  <id>~/topic/26158/kak-my-s-pomoshshyu-ii-pishem-konnektory-k-kriptobirzham/</id>
  <rights type="text">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  <updated>2026-06-14T05:40:00Z</updated>
  <logo>https://stocksharp.ru/images/logo.png</logo>
  <link href="https://stocksharp.ru/handlers/atom.ashx?category=topic&amp;id=26158" rel="self" type="application/rss+xml" />
  <entry>
    <id>https://stocksharp.ru/posts/m/83155/</id>
    <title type="text">Или как ИИ может сэкономить вам часы работы, но не спасёт от необходимости проверять каждый шаг. cla...</title>
    <published>2024-09-04T21:35:45Z</published>
    <updated>2024-09-05T05:54:45Z</updated>
    <author>
      <name>StockSharp</name>
      <uri>https://stocksharp.ru/users/1/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;&lt;em&gt;Или как ИИ может сэкономить вам часы работы, но не спасёт от необходимости проверять каждый шаг.&lt;/em&gt;&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154508/claudeai-vs-chatgpt.jpg" alt="claudeai-vs-chatgpt.jpg" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;Сентябрь 2024 года. Мы, команда &lt;strong&gt;StockSharp&lt;/strong&gt;, активно используем ИИ для написания коннекторов к криптобиржам. Но спешу вас предупредить — если вы читаете эту статью в 2025 году или позже, всё это может уже устареть. Если вы из будущего, добро пожаловать в прошлое! И не забудьте проверить, актуальны ли наши методы.&lt;/p&gt;
&lt;p&gt;Наш путь с ИИ начался с &lt;strong&gt;ChatGPT 3.5&lt;/strong&gt;, который, откровенно говоря, не мог бы написать не то что коннектор для криптобиржи, а даже простую торговую стратегию. Однако с приходом &lt;strong&gt;ChatGPT 4.0&lt;/strong&gt; и &lt;strong&gt;Claude Sonnet 3.5&lt;/strong&gt; ситуация резко изменилась. Теперь ИИ может писать сложные модули кода, хотя и с оговорками: приходится вмешиваться, уточнять и исправлять ошибки, что, впрочем, стало уже нормой в нашем процессе.&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="claude.ai"&gt;Шаг 1. Запуск проекта в Claude.ai&lt;/h2&gt;
&lt;p&gt;Прежде чем начать писать новый коннектор, первым делом мы создаём &lt;strong&gt;проект в Claude.ai&lt;/strong&gt;. Это не просто чат, который забудет всё, как только вы его закроете. Проект позволяет сохранять всё, что вы туда загружаете: коды, документы, комментарии. Это аналог настроек &lt;strong&gt;Custom GPT&lt;/strong&gt;, где ИИ «учится» на ваших примерах и указаниях, а не просто отвечает на вопросы.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154507/claude-project.png" alt="project.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Интерфейс создания проекта в Claude.ai. Здесь сохраняются все данные и примеры, что позволяет поддерживать контекст работы.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Claude.ai — это как ваш личный программист, который что-то понимает, но без вашего надзора может написать что-то, от чего волосы на голове зашевелятся. Так что держите рядом документацию и свою бдительность.&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="section"&gt;Шаг 2. Копируем существующий код&lt;/h2&gt;
&lt;p&gt;Чтобы не изобретать велосипед каждый раз, мы берем за основу уже существующий коннектор, например, для &lt;strong&gt;Coinbase&lt;/strong&gt;. Мы копируем структуру проекта и адаптируем все ключевые классы и методы под новую биржу. Это только начало пути — дальше начинается самое интересное.&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="websocket"&gt;Шаг 3. Адаптация WebSocket клиента&lt;/h2&gt;
&lt;p&gt;Теперь пора настраивать WebSocket клиента для новой биржи. Для примера возьмем &lt;strong&gt;GateIO Spot WebSocket v4&lt;/strong&gt;. Claude.ai помогает с генерацией кода, но тут начинается наша постоянная борьба с неточностями. ИИ частенько генерирует код, который в теории кажется правильным, но на практике нужно дополнять и исправлять.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154495/1.png" alt="1.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Исходный код WebSocket клиента для одной из бирж, сгенерированный Claude.ai. ИИ предлагает расширить типы данных и события.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Когда доходит до аутентификации, ИИ часто ошибается, и приходится вручную добавлять недостающие элементы. Claude может забыть даже такие базовые вещи, как авторизация перед подпиской на каналы WebSocket.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154486/2.png" alt="2.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Claude.ai допустил ошибку при реализации авторизации WebSocket. Мы исправили код и добавили корректную авторизацию перед подключением.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Мы также переделываем код так, чтобы сделать его более гибким и передавать адрес WebSocket через параметр. Это позволяет нам легко адаптироваться к различным биржам и их API.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154499/3.png" alt="3.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Пример кода, где веб-сокет передается как параметр, что делает архитектуру более гибкой.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="rest"&gt;Шаг 4. Настройка REST клиента и адаптера&lt;/h2&gt;
&lt;p&gt;После настройки WebSocket клиента мы приступаем к REST клиенту. Claude.ai генерирует базовые запросы, но нам приходится вручную уточнять, корректны ли они. API бирж отличаются, и нужно быть внимательным, чтобы не пропустить важные детали в документации.&lt;/p&gt;
&lt;p&gt;Когда клиент готов, мы переходим к адаптеру для &lt;strong&gt;StockSharp&lt;/strong&gt;, где происходит основная магия — обработка данных и их приведение к единому формату. Тут ИИ помогает с генерацией классов, но всегда стоит сверять каждый шаг. Особенно это важно при работе с JSON данными, передаваемыми через API биржи.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154488/5.png" alt="5.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Сгенерированные классы для доменной модели. Мы вручную дополнили их атрибутами и исправили типы данных.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Claude может предложить интересные решения, но нужно добавлять атрибуты, такие как &lt;strong&gt;JsonProperty&lt;/strong&gt;, чтобы корректно обрабатывать данные биржи. Если вы этого не сделаете — готовьтесь к сюрпризам в виде неверных данных в отчётах.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154493/6.png" alt="6.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Мы добавили атрибуты JsonProperty для правильной работы с JSON данными.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Обработка торговых данных — ещё один важный этап, где ИИ не всегда справляется самостоятельно. Например, данные сделок и их обработка могут вызывать ошибки.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154497/7.png" alt="7.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Claude исправляет код для обработки данных торгов, передаваемых через WebSocket и REST API.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="section-1"&gt;Шаг 5. Оптимизация и новые методы&lt;/h2&gt;
&lt;p&gt;Claude.ai неплохо справляется с написанием базовых методов, таких как работа со свечами и торговыми данными. Однако его предложения требуют оптимизации. Мы часто выносим логику в отдельные классы для лучшей структуры.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154489/8.png" alt="8.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Оптимизация методов для работы со свечами и данными торговли через WebSocket, вынесенные в отдельные классы.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Также приходится дорабатывать методы для работы с торговыми операциями через WebSocket. И хотя ИИ помогает автоматизировать такие процессы, код всё равно требует финальной доводки.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154494/9.png" alt="9.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Claude.ai добавил методы для торговых операций в SocketClient, но их пришлось оптимизировать и исправить ошибки.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="section-2"&gt;Шаг 6. Тестирование — код работает не всегда с первой попытки&lt;/h2&gt;
&lt;p&gt;Когда код готов, самое время его протестировать. Здесь ИИ снова приходит на помощь, но все его предложения нужно тщательно проверять, потому что часто с первого раза всё работает некорректно. Например, при тестировании работы с API биржи мы сталкиваемся с ошибками при запросах инструментов и позиций.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154490/10.png" alt="10.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Claude.ai предложил код для работы с REST API Gate.io, но его нужно было тестировать и дорабатывать.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="section-3"&gt;Шаг 7. Конвертация данных для спота и деривативов&lt;/h2&gt;
&lt;p&gt;Claude.ai помогает с генерацией классов для работы со спотом и деривативами, но опять же — будьте готовы к тому, что нужно будет корректировать методы и типы данных вручную. Например, работа с деривативами на Gate.io требует дополнительных проверок и доработок.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154492/11.png" alt="11.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Claude.ai предложил класс Extensions для поддержки конвертации данных между спотом и деривативами на Gate.io.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Мы также адаптируем &lt;strong&gt;SpotAdapter&lt;/strong&gt; для корректной обработки данных биржи, используя методы конвертации, предложенные Claude.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154498/12.png" alt="12.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;SpotAdapter был переписан с учетом изменений в HttpClient и SocketClient, используя методы из Extensions.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="section-4"&gt;Шаг 8. Адаптер для фьючерсов и исправления ошибок&lt;/h2&gt;
&lt;p&gt;Claude.ai помогает с написанием методов для работы с фьючерсами, но, как и прежде, требуется тщательная проверка логики и исправление ошибок. Например, при сборке стакана данных мы столкнулись с проблемой обработки исключений.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154496/13.png" alt="13.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Сгенерированный HttpClient для работы с фьючерсами через REST API Gate.io.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;Claude также иногда ошибается с обработкой данных в адаптере фьючерсов. Приходится вручную настраивать методы для правильной работы со стаканом.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154491/14.png" alt="14.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Исправленный адаптер для фьючерсов с правильной логикой работы со стаканом.&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;В результате после исправлений ИИ предложил оптимизированный метод для работы с ордербуками и восстановления данных.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154501/15.png" alt="15.png" /&gt;&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;strong&gt;Оптимизация методов для восстановления и работы со стаканом данных на основе предложений Claude.ai.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id="github-copilot"&gt;GitHub Copilot — разрекламированная игрушка или настоящий помощник?&lt;/h2&gt;
&lt;p&gt;GitHub Copilot, который Microsoft и GitHub активно продвигают как инструмент будущего, на самом деле в своём текущем виде является скорее интересной игрушкой, нежели полноценным помощником программиста. Copilot помогает писать нужные участки кода, но по-настоящему выдающихся результатов от него ждать не стоит — его сила в доработке и предложениях по улучшению кода. Однако его главный плюс — это тесная интеграция со средой разработки, что делает его удобным для быстрых правок и завершения шаблонного кода, с чем он справляется гораздо лучше, чем написание сложных логических модулей.&lt;/p&gt;
&lt;div style="text-align:center"&gt;&lt;p&gt;&lt;img src="/file/154506/copilot.gif" alt="copilot.gif" /&gt;&lt;/p&gt;
&lt;/div&gt;&lt;hr /&gt;
&lt;h2 id="section-5"&gt;ИИ: усилитель возможностей для профессионалов и преграда для новичков&lt;/h2&gt;
&lt;p&gt;Если вы начинающий разработчик и только погружаетесь в мир программирования, то вам, мягко говоря, не повезло. На текущий момент ИИ никак не повысит вашу эффективность. Более того, доверяя ИИ в сложных задачах, вы можете ещё больше запутаться в коде и проблемах, которые он генерирует. Совсем другое дело — опытные программисты.&lt;/p&gt;
&lt;p&gt;Для профессионалов ИИ действительно становится мощным инструментом, который преумножает их возможности: увеличивает скорость разработки, предлагает решения, обогащает знания о различных технологиях и библиотеках. В таком тандеме ИИ помогает фокусироваться на ключевых аспектах проекта, оставляя рутину на его плечах.&lt;/p&gt;
&lt;p&gt;Однако, как мы уже упоминали, ИИ бьёт по самому слабому месту — начинающим разработчикам, делая разрыв между ними и профессионалами ещё большим. Опытные программисты могут быстро выявить ошибки ИИ, исправить их и продолжить работу, тогда как новичок просто утонет в этих проблемах. Иронично, что в то время, когда ИИ задумывался как помощь для всех, он пока лишь увеличивает этот разрыв.&lt;/p&gt;
&lt;p&gt;Но стоит надеяться, что в будущем ИИ станет более самостоятельным в программировании, и тогда этот разрыв может не только перестать расти, но и вовсе исчезнуть, выравнивая шансы для всех, независимо от их уровня подготовки.&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
</feed>