آموزش جامع ساخت ربات معامله‌گر

ربات معامله گر، برنامه نویسی، ارز دیجیتال، فارکس 1404/5/21
نویسنده: مدرس بهمن آبادی

آموزش جامع ساخت ربات معامله‌گر

آموزش جامع ساخت ربات معامله‌گر

مقدمه

ربات‌های معامله‌گر (Trading Bots) برنامه‌هایی هستن که به‌صورت خودکار معاملات مالی رو در بازارهای سهام، فارکس یا ارزهای دیجیتال انجام می‌دن. این ربات‌ها با تحلیل داده‌های بازار و اجرای استراتژی‌های از پیش تعریف‌شده، می‌تونن سودآوری رو افزایش بدن و زمان معامله‌گر رو صرفه‌جویی کنن. در این آموزش، به‌صورت گام‌به‌گام یاد می‌گیرید چطور یه ربات معامله‌گر ساده با C# بسازید که قیمت‌های ارز دیجیتال (مثل بیت‌کوین) رو از یه API دریافت کنه و بر اساس استراتژی میانگین متحرک (Moving Average) معامله کنه. این مقاله برای مبتدی‌ها و حرفه‌ای‌ها طراحی شده است.

چرا ربات معامله‌گر با C#؟

زبان C# به دلایل زیر برای ساخت ربات معامله‌گر مناسبه:

  • عملکرد بالا: با فریم‌ورک .NET، اجرای سریع و مدیریت بهینه منابع.

  • کتابخانه‌های قوی: پشتیبانی از HTTP Client برای اتصال به APIهای بازار.

  • جامعه فعال: منابع آموزشی و پکیج‌های متن‌باز (مثل RestSharp یا Newtonsoft.Json).

  • انعطاف‌پذیری: مناسب برای استراتژی‌های مختلف معاملاتی و ادغام با پایگاه داده.

  • امنیت: امکان رمزنگاری داده‌ها و مدیریت کلیدهای API.

پیش‌نیازها

قبل از شروع، این موارد رو آماده کنید:

Visual Studio 2022 یا Visual Studio Code با .NET 9 SDK.

دانش پایه C# (متغیرها، حلقه‌ها، توابع).

کلید API از یه سرویس داده بازار (مثل Alpha Vantage یا Binance). برای ایرانی‌ها، به دلیل تحریم‌ها، از صرافی‌های داخلی مثل نوبیتکس یا APIهای رایگان مثل CoinGecko استفاده کنید.

نصب پکیج‌های NuGet: RestSharp و Newtonsoft.Json.

اتصال اینترنت پایدار برای دریافت داده‌های بازار.

دوره جامع برنامه‌نویسی وب مهندس بهمن آبادی در بخش‌های پیشرفته، کار با APIها، برنامه‌نویسی ناهمگام (Async) و مدیریت داده‌ها رو با پشتیبانی دائمی آموزش می‌ده که برای ساخت ربات‌های معامله‌گر کاربردیه.

گام‌های ساخت ربات معامله‌گر با C#

گام ۱: ایجاد پروژه و نصب پکیج‌ها

  1. ایجاد پروژه جدید:

  • Visual Studio رو باز کنید و Create a new project رو انتخاب کنید.
  • قالب Console App رو با .NET 9.0 انتخاب کنید.
  • نام پروژه رو TradingBot بذارید.
  1. نصب پکیج‌های لازم:

    • در Visual Studio، به Tools > NuGet Package Manager > Manage NuGet Packages for Solution برید.

    • پکیج‌های RestSharp و Newtonsoft.Json رو نصب کنید.

    • یا از ترمینال این دستورات رو اجرا کنید:

dotnet add package RestSharp
dotnet add package Newtonsoft.Json

آموزش جامع ساخت ربات معامله‌گر

گام ۲: دریافت داده‌های بازار

برای این آموزش، از API رایگان CoinGecko استفاده می‌کنیم که نیازی به کلید API نداره و برای ایرانی‌ها در دسترسه.

  1. ساخت مدل داده:

    • یه کلاس برای ذخیره داده‌های قیمت ایجاد کنید:

using System;

namespace TradingBot {

public class PriceData {

public decimal Price { get; set; }

public DateTime Timestamp { get; set; }

}

}

       2. دریافت قیمت از CoinGecko:
  • کد زیر قیمت بیت‌کوین رو دریافت می‌کنه:
using System;
using System.Net.Http;
using System.Threading.Tasks;
using Newtonsoft.Json.Linq;

namespace TradingBot
{
    public class CoinGeckoService
    {
        private readonly HttpClient _httpClient;

        public CoinGeckoService()
        {
            _httpClient = new HttpClient
            {
                BaseAddress = new Uri("https://api.coingecko.com/api/v3/")
            };
        }

        public async Task<PriceData> GetBitcoinPriceAsync()
        {
            try
            {
                var response = await _httpClient.GetStringAsync("simple/price?ids=bitcoin&vs_currencies=usd");
                var json = JObject.Parse(response);
                decimal price = json["bitcoin"]["usd"].Value<decimal>();
                return new PriceData
                {
                    Price = price,
                    Timestamp = DateTime.UtcNow
                };
            }
            catch (Exception ex)
            {
                Console.WriteLine($"خطا در دریافت قیمت: {ex.Message}");
                return null;
            }
        }
    }

}

توضیح: این کد قیمت بیت‌کوین رو به دلار از CoinGecko می‌گیره و در شیء PriceData ذخیره می‌کنه. دوره جامع برنامه‌نویسی وب در بخش کار با API، استفاده از HttpClient و JSON رو آموزش می‌ده.

گام ۳: پیاده‌سازی استراتژی معامله

آموزش جامع ساخت ربات معامله‌گر

استراتژی ساده میانگین متحرک (Moving Average Crossover) رو پیاده می‌کنیم:

  • وقتی میانگین متحرک کوتاه‌مدت (مثلاً ۵ دقیقه) از میانگین بلندمدت (مثلاً ۲۰ دقیقه) عبور کنه، سیگنال خرید یا فروش تولید می‌شه.
  1. ساخت کلاس استراتژی:

using System;
using System.Collections.Generic;
using System.Linq;

namespace TradingBot
{
    public class TradingStrategy
    {
        private readonly List<PriceData> _prices = new List<PriceData>();
        private readonly int _shortPeriod = 5;
        private readonly int _longPeriod = 20;

        public void AddPrice(PriceData price)
        {
            _prices.Add(price);
            if (_prices.Count > _longPeriod)
                _prices.RemoveAt(0);
        }

        public string GetSignal()
        {
            if (_prices.Count < _longPeriod)
                return "داده کافی نیست";

            var shortMA = _prices.TakeLast(_shortPeriod).Average(p => p.Price);
            var longMA = _prices.TakeLast(_longPeriod).Average(p => p.Price);

            if (shortMA > longMA && _prices[^2].Price <= _prices[^2].Price)
                return "خرید";
            else if (shortMA < longMA && _prices[^2].Price >= _prices[^2].Price)
                return "فروش";
            else
                return "منتظر بمان";
        }
    }
}

 

توضیح: این کد میانگین متحرک کوتاه‌مدت و بلندمدت رو محاسبه می‌کنه و سیگنال خرید، فروش یا انتظار تولید می‌کنه.

گام ۴: اجرای ربات

  1. ساخت برنامه اصلی:
    • فایل Program.cs رو با کد زیر جایگزین کنید:

using System;
using System.Threading.Tasks;

namespace TradingBot
{
    class Program
    {
        static async Task Main(string[] args)
        {
            var coinGecko = new CoinGeckoService();
            var strategy = new TradingStrategy();

            Console.WriteLine("ربات معامله‌گر شروع شد...");

            while (true)
            {
                var priceData = await coinGecko.GetBitcoinPriceAsync();
                if (priceData != null)
                {
                    Console.WriteLine($"قیمت بیت‌کوین: {priceData.Price} دلار در {priceData.Timestamp}");
                    strategy.AddPrice(priceData);
                    var signal = strategy.GetSignal();
                    Console.WriteLine($"سیگنال: {signal}");
                }

                await Task.Delay(60000); // انتظار ۱ دقیقه
            }
        }
    }
}

 

توضیح:
  • این کد هر دقیقه قیمت بیت‌کوین رو دریافت می‌کنه، به استراتژی اضافه می‌کنه و سیگنال معامله رو نمایش می‌ده.
  • برای جلوگیری از درخواست‌های بیش از حد، از Task.Delay استفاده شده.

 

گام ۵: تست و دیباگ

  1. اجرای پروژه:
    • با Ctrl+F5 پروژه رو اجرا کنید.
    • خروجی کنسول باید قیمت‌های بیت‌کوین و سیگنال‌های خرید/فروش رو نشون بده.
  2. دیباگ:
    • در Visual Studio، نقاط توقف (Breakpoint) در متد GetSignal بذارید تا مقادیر میانگین متحرک رو بررسی کنید.
    • از ابزار توسعه‌دهنده Chrome برای بررسی درخواست‌های API استفاده کنید.

دوره جامع برنامه‌نویسی وب در بخش دیباگ، تکنیک‌های اشکال‌زدایی و کار با APIها رو با پشتیبانی دائمی آموزش می‌ده.

گام ۶: افزودن قابلیت معامله واقعی

برای معامله واقعی، باید به API صرافی (مثل نوبیتکس برای ایرانی‌ها) متصل بشید:

  1. ثبت‌نام در صرافی:
    • در نوبیتکس ثبت‌نام کنید و کلید API رو دریافت کنید.
    • کلیدها رو در appsettings.json ذخیره کنید:

{
  "Nobitex": {
    "ApiKey": "YOUR_API_KEY",
    "ApiSecret": "YOUR_API_SECRET"
  }

}

2. ارسال سفارش:

  • کد نمونه برای ارسال سفارش خرید (به دلیل تحریم‌ها، فقط ساختار کلی ارائه شده):

using System;
using System.Net.Http;
using System.Threading.Tasks;

namespace TradingBot
{
    public class NobitexService
    {
        private readonly HttpClient _httpClient;
        private readonly string _apiKey;

        public NobitexService(string apiKey)
        {
            _httpClient = new HttpClient();
            _apiKey = apiKey;
        }

        public async Task<bool> PlaceBuyOrderAsync(decimal amount, decimal price)
        {
            try
            {
                // نمونه کد - به مستندات نوبیتکس مراجعه کنید
                Console.WriteLine($"ارسال سفارش خرید: {amount} بیت‌کوین با قیمت {price} دلار");
                return true;
            }
            catch (Exception ex)
            {
                Console.WriteLine($"خطا در سفارش: {ex.Message}");
                return false;
            }
        }
    }
}

 

 

توجه: برای پیاده‌سازی واقعی، به مستندات API نوبیتکس مراجعه کنید و امضای درخواست (Signature) رو طبق دستورالعمل اضافه کنید.

گام ۷: انتشار و بهینه‌سازی

  1. انتشار ربات:
    • از دستور زیر برای انتشار استفاده کنید: 

dotnet publish -c Release

نکته :
  • به دلیل تحریم‌ها، از صرافی‌های داخلی مثل نوبیتکس یا والکس استفاده کنید.
  • برای نقد کردن درآمد دلاری، از تتر (USDT) و صرافی‌های معتبر مثل نوبیتکس استفاده کنید.

آموزش جامع ساخت ربات معامله‌گر

مزایا و چالش‌های ربات معامله‌گر

مزایا

  • اتوماسیون معاملات و صرفه‌جویی در زمان.
  • اجرای استراتژی‌های دقیق بدون تأثیر احساسات.
  • امکان تست استراتژی‌ها با داده‌های تاریخی.
  • قابلیت ادغام با صرافی‌های مختلف.

چالش‌ها

  • نیاز به اینترنت پایدار و سرور امن.
  • تحریم‌ها برای دسترسی به صرافی‌های بین‌المللی (راه‌حل: صرافی‌های داخلی).
  • ریسک مالی در صورت خطا در استراتژی.
  • نیاز به دانش برنامه‌نویسی و تحلیل بازار.

نتیجه‌گیری

ساخت ربات معامله‌گر با C# راهی عالی برای ورود به دنیای معاملات خودکاره که با استفاده از APIهای بازار و استراتژی‌های ساده مثل میانگین متحرک، می‌تونید سودآوری رو افزایش بدید. این آموزش یه ربات پایه با CoinGecko و استراتژی Moving Average ارائه داد که می‌تونه با صرافی‌های داخلی مثل نوبیتکس گسترش پیدا کنه. دوره جامع برنامه‌نویسی وب مهندس بهمن آبادی با پشتیبانی دائمی، شما رو برای کار با APIها، دیتابیس و بهینه‌سازی ربات‌ها آماده می‌کنه و شما می‌تونید ربات‌های حرفه‌ای بسازید و در بازارهای مالی یا استارتاپ‌ها موفق بشید.

منابع