Создание простого привода на S#
Atom
25.05.2012


Бесплатная библиотека StockSharp предоставляет широкие возможности при разработке торговых роботов различной сложности. Но самое трудное для многих пользователей - сделать первые шаги при разработке своего робота. Поэтому представляем вашему вниманию статью-инструкцию по созданию простого привода для терминала QUIK с использованием S#.API.

Для создания простого привода нам понадобится:
1) Quik;
2) Библиотека S#;
3) Visual Studio Express;
4) Немного навыков программирования.

Подготовка рабочего места



После установки Quik, его нужно настроить для работы со S#. Для этого нужно проделать 3 базовых шага:

1) Включить обработку внешних транзакций. "Торговля" → "Внешние Транзакции" → "Начать обработку" и поставить галочку "Запускать процесс обработки внешних транзацкий автоматически"

2) Далее нужно открыть соответствующий Wnd-файл с настройками: "Настройки" → "Загрузить настройки из файла" → выбрать wnd-файл по пути "Разахивированная папка"\Samples\Quik\info.wnd

3) Далее настраиваем счета : "Торговля" → "Настройка счетов" → добавить все счета в выбранные счета депо.

4) В итоге можно настроить окошки - подтянуть их, уменьшить, но названия столбцов менять нельзя, так же как и удалять их. У разных брокеров (квиков) есть особенности , стоят определённые фильтры на таблицах "Мои сделки", "Мои заявки". Нажав правой кнопкой мышки на таблицу "Мои сделки", выделить все. Аналогично и в таблице “Мои заявки”.

Добавьте торгующийся на данный момент инструмент в таблицу "Инструменты"; по нему в дальнейшем мы будем отправлять заявки.

Создание торгового привода

Открываем Visual Studio.
Создаём новый проект → "Приложение Wpf".
Настраиваем наш проект на работу S#:
  • Правой кнопкой мыши на "Проект" → "Свойства" и меняем "Требуемая версия NetFrameWork" (Net FrameWork 4 Client Profile ) на просто Net FrameWork 4(после этого меняется целевая среда разарботки).
  • Добавляем нужные библиотеки в наш проект "Ссылки" → "Добавить ссылку" → "Обзор".
  • Выбираем нужные нам библиотеки, которые лежат в "Разахрихированая папка"\References:
    1)StockSharp.Quik
    2)StockSharp.BusinessEntites
    3)StockSharp.Algo
    4)Ecng.Common
    5)Ecng.ComponentModel
    6)Ecng.Xaml
  • Прописываем соответсвующие using на наши библиотеки в классе MainWindow.xaml.cs

Код
using System.Windows;
using StockSharp.Quik;
using Ecng.Xaml;
using StockSharp.BusinessEntities;

Заходим в MainWindow.Xaml, создаём соответсвующие кнопки и другие элементы на форме нашего приложения, перетягивая их из панели элементов. Получаем следующую форму:

Даем каждому элементу на нашей форме название, чтобы потом из кода обращаться к нему.
Нажимаем два раза на кнопку, чтобы создать метод, который будет вызываться по нажатию на эту кнопку (метод обработчик).

Прописываем код под кнопку подключения.
Это простой код демонстрирующий подключение и выгрузку данных из Quik в асинхронном режиме. Теперь осталось дополнить код выводом информации на главную форму, то есть сделать вывод в наши выпадающие списки "Портфели" и "Инструменты".
Код
//обьявляем переменную
        private QuikTrader _trader;
        /// <summary>
        /// Подключение к квику
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void Connect_Click(object sender, RoutedEventArgs e)
        {
            //создаём квик трейдера, передавая ему сразу место расположения нашего терминала
            _trader= new QuikTrader(QuikTerminal.GetDefaultPath());
            //подписываемся на событие подключения, как только подлючимся, сразу запустим Экспорт
            //Connect- просто подключение к потоку
            //StartExport- получение он-лайн данных из квика Инструменты,Заявки , Портфели и так далее
            _trader.Connected += () => _trader.StartExport();
            // подключаем квик 
            _trader.Connect();

        }

Дописываем графический вывод на нашу форму в выпадающие списки:
Код
private void Connect_Click(object sender, RoutedEventArgs e)
        {
            //создаём квик трейдера, передавая ему сразу место расположения нашего терминала
            _trader= new QuikTrader(QuikTerminal.GetDefaultPath());
            //подписываемся на событие появление новых инструментов
            //оно сработает когда включится экспорт 
            _trader.NewSecurities += securities =>this.GuiAsync(()=>//GuiASync используется чтобы выводить графику из другого потока
                                                                    {
                                                                        //заполняем коллекцию у нашего выпадающего списка (ComboBox)
                                                                        Securitites.ItemsSource = _trader.Securities;
                                                                    });
            //подписываемся на событие появления новых портфелей
            //сработает после запуска экспорта
            _trader.NewPortfolios += portfolios =>this.GuiAsync(()=>
                                                                    {
                                                                        //заполняем коллекцию у нашего выпадающего списка (ComboBox)
                                                                        Portfolios.ItemsSource = _trader.Portfolios;
                                                                    });
            
            //подписываемся на событие подключения, как только подлючимся, сразу запустим Экспорт
            //Connect - просто подключение к потоку
            //StartExport- получение онлайн данных из квика Инструменты, Заявки, Портфели и так далее
            _trader.Connected += () => _trader.StartExport();
            // подключаем квик 
            _trader.Connect();

        }

Запускаем проект (F5), нажимаем на кнопку "Подключиться" (в это время у нас уже работает Quik, который подключен к котировкам). После этого наш робот включает эскпорт DDE в Quik и через некоторое время мы получаем заполненные выпадающие списки в нашем проекте.

Остается дописать функционал под две оставшиеся кнопки "Купить", "Снять все заявки":
  • "Купить" - отправляем заявку (портфель и инструмент берется из выпадающих списков) по той цене, которая будет указана в нашем текстовом окне;
  • "Снять все заявки" - снимаем все выставленные нами заявки.

Код для отправки заявки:
Код
private void Buy_Click(object sender, RoutedEventArgs e)
        {
            //создаём ордер
            //заполняем его нужными свойствами
            // портфель и инструмент вынимаем из выпадающих списков
            //цену для отправки заявки вынимаем из тесктового окна
            var order = new Order
                            {
                                Trader = _trader,
                                Portfolio = (Portfolio)Portfolios.SelectedItem,
                                Security = (Security) Securitites.SelectedItem,
                                Volume = 1,
                                Price = decimal.Parse(PRICE.Text),
                                Direction = OrderDirections.Buy
                            };
            //регистрируем ордер
            _trader.RegisterOrder(order);
        }

Код для снятия всех заявок:
Код
private void CancelOrders_Click(object sender, RoutedEventArgs e)
        {
            //отменить все заявки
            _trader.CancelOrders();
        }

Пример работы простого привода:

Скачать исходники также можно здесь.

Видео-урок по созданию простого торгового робота с использованием библиотеки StockSharp:



Автор статьи: Самунджян Артём


<< < 3 4 5 6  >
Кот Матроскин

Фотография
Дата: 13.06.2012
Ответить


Smelov Перейти
В списке находятся значения типа SBER@QJSIM

А что это за тип такой QJSIM? В марте делал список доступных инструментов, такого типа и в помине не было...
Спасибо:

Smelov

Фотография
Дата: 13.06.2012
Ответить


Кот Матроскин Перейти
Smelov Перейти
В списке находятся значения типа SBER@QJSIM

А что это за тип такой QJSIM? В марте делал список доступных инструментов, такого типа и в помине не было...

Это класс инструмента. строка в combobox выглядит следующим образом: код_инструмента@класс_инструмента

p.s. имхо, QJSIM это quik junior simulator
p.p.s в примере wpf-проекта combobox заполняется таким же образом
Спасибо:

Кот Матроскин

Фотография
Дата: 13.06.2012
Ответить


Честно говоря, не с WinForms не дружу
Спасибо:

Smelov

Фотография
Дата: 13.06.2012
Ответить


Кот Матроскин Перейти
Честно говоря, не с WinForms не дружу

Да здесь больше дело в DataGridView
Спасибо:

Творог

Фотография
Дата: 27.10.2012
Ответить


Почему у меня такая ошибка в строке
private QuikTrader _trader; ?
Вроде бы все требуемые ссылки добавил.
ssr.jpg 201 KB (211)
Спасибо:

Moadip

Фотография
Дата: 27.10.2012
Ответить


Судя по скрину у вас не добавлена StockSharp.Logging.dll и не прописано соответсвующее namespace.
Раньше классы для работы с логами были в StockSharp.Algo.dll. Сейчас вынесены в отдельную dll.
Спасибо: Творог

Творог

Фотография
Дата: 27.10.2012
Ответить


Ага, StockSharp.Logging.dll и Ecng.Serialization.dll надо добавить. В статье про это не сказано, устарела.
Спасибо:

fly2k

Фотография
Дата: 19.11.2013
Ответить


у меня у одного нет файла Samples/info.wnd ? :o
Спасибо:

boev_a@bk.ru

Фотография
Дата: 17.10.2014
Ответить


Подскажите что делать если, в комбобоксах не выдаётся список, где находятся лог файлы ?
Спасибо:

Mercury13

Фотография
Дата: 12.01.2015
Ответить


Добрый день!

Заинтересовала платформа, видно, что имеется много полезных возможностей. Однако, пример из коробки у меня не пошел, выдает ошибку в отроке

_trader.RegisterOrder(order);

Ошибка следующего вида
"System.ArgumentNullException" в StockSharp.Algo.dll
{"Значение не может быть неопределенным.\r\nИмя параметра: classCode"}

Возможно что-то изменилось в библиотеке, за это время, у меня стоит сейчас последняя версия.
Буду благодарен за помощь.

Заранее спасибо.
Спасибо:
<< < 3 4 5 6  >

Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy