Форум программистов, компьютерный форум, киберфорум
C#: API, боты
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 09.12.2025
Сообщений: 3
Telegram Bot

Тг бот для заказа справок из отдела кадров

09.12.2025, 15:37. Показов 947. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Text.Json.Serialization;
using System.Threading;
using System.Threading.Tasks;
using System.Xml;
using Telegram.Bot;
using Telegram.Bot.Args;
using Telegram.Bot.Polling;
using Telegram.Bot.Types;
using Telegram.Bot.Types.Enums;
//using Telegram.Bot.Types.InlineKeyboardButtons;
using Telegram.Bot.Types.ReplyMarkups;
 
 
namespace HRBot
{
    class Program
    {
        // Токен бота
        private static readonly string BotToken = "<token>";
 
        // Файлы данных
        private static readonly string UsersFile = "users.json";
        private static readonly string RequestsFile = "requests.json";
        private static readonly string StaffFile = "staff.json";
 
        // Данные
        private static Dictionary<string, UserData> users = new Dictionary<string, UserData>();
        private static Dictionary<string, RequestData> requests = new Dictionary<string, RequestData>();
        private static Dictionary<string, StaffData> staff = new Dictionary<string, StaffData>();
 
        // Состояния пользователей
        private static Dictionary<long, UserState> userStates = new Dictionary<long, UserState>();
        private static Dictionary<long, TempUserData> tempData = new Dictionary<long, TempUserData>();
 
        // Типы справок
        private static readonly Dictionary<string, string> SpravkiTypes = new Dictionary<string, string>
        {
            ["1"] = "Справка о зачислении",
            ["2"] = "Справка о стипендии",
            ["3"] = "Справка об обучении",
            ["4"] = "Справка для военкомата",
            ["5"] = "Справка на работу",
            ["6"] = "Другая справка"
        };
 
        private static TelegramBotClient botClient;
 
        static void Main(string[] args)
        {
            Console.WriteLine("Запуск бота для заказа справок...");
 
            // Инициализация файлов
            InitializeFiles();
 
            // Загрузка данных
            LoadAllData();
 
            // Создание клиента бота
            botClient = new TelegramBotClient(BotToken);
 
            // Настройка обработки сообщений
            botClient.OnMessage += Bot_OnMessage;
            botClient.OnCallbackQuery += Bot_OnCallbackQuery;
            botClient.OnReceiveError += Bot_OnReceiveError;
            botClient.OnReceiveGeneralError += Bot_OnReceiveGeneralError;
            // Запуск бота
            Console.WriteLine("Бот запущен! Нажмите любую клавишу для завершения...");
            Console.ReadKey();
            // Остановка бота
        }
 
        // Инициализация файлов
        static void InitializeFiles()
        {
            if (!File.Exists(UsersFile))
                File.WriteAllText(UsersFile, "{}");
 
            if (!File.Exists(RequestsFile))
                File.WriteAllText(RequestsFile, "{}");
 
            if (!File.Exists(StaffFile))
                File.WriteAllText(StaffFile, "{}");
        }
 
        // Загрузка всех данных
        static void LoadAllData()
        {
            try
            {
                if (File.Exists(UsersFile))
                {
                    string usersJson = File.ReadAllText(UsersFile);
                    users = JsonConvert.DeserializeObject<Dictionary<string, UserData>>(usersJson) ?? new Dictionary<string, UserData>();
                }
 
                if (File.Exists(RequestsFile))
                {
                    string requestsJson = File.ReadAllText(RequestsFile);
                    requests = JsonConvert.DeserializeObject<Dictionary<string, RequestData>>(requestsJson) ?? new Dictionary<string, RequestData>();
                }
 
                if (File.Exists(StaffFile))
                {
                    string staffJson = File.ReadAllText(StaffFile);
                    staff = JsonConvert.DeserializeObject<Dictionary<string, StaffData>>(staffJson) ?? new Dictionary<string, StaffData>();
                }
            }
            catch (Exception ex)
            {
                Console.WriteLine($"Ошибка загрузки данных: {ex.Message}");
            }
        }
 
        // Сохранение данных
        static void SaveData<T>(string filename, Dictionary<string, T> data)
        {
            try
            {
                string json = JsonConvert.SerializeObject(data, Formatting.Indented);
                File.WriteAllText(filename, json);
            }
            catch (Exception ex)
            {
                Console.WriteLine($"Ошибка сохранения данных: {ex.Message}");
            }
        }
 
        // Обработка сообщений
        private static async void Bot_OnMessage(object sender,Message e)
        {
            var message = e.Message;
 
            if (message == null || message.Type != MessageType.Text)
                return;
 
            long userId = message.From.Id;
            string text = message.Text;
 
            // Команда /start
            if (text.StartsWith("/start"))
            {
                await StartCommand(message);
                return;
            }
Всем привет ,впервые на вашем форуме ,буду очень благодарен за помощь главная ошибка в Message и в обработке сообщений
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.12.2025, 15:37
Ответы с готовыми решениями:

Библиотеки для захвата кадра с сетевой камеры
Доброго времени суток, уважаемые мастера и знатоки своего дела! Помогите, пожалуйста, с поиском...

Достать кадр из видео и вставить на сайт
Как можно достать кадр из видео, и вставить на сайт. Сайт что-то вроде ютуба, хочу чтоб после...

Корзина заказов для интернет магазина
Каким образом организовать корзину заказов в ASP.Net MVC проекте? Пишу небольшую работу для учебы...

9
Администратор
 Аватар для mik-a-el
87893 / 53214 / 249
Регистрация: 10.04.2006
Сообщений: 13,768
09.12.2025, 16:02
mashasokol.soko, что делает этот код?
0
0 / 0 / 0
Регистрация: 09.12.2025
Сообщений: 3
09.12.2025, 16:05  [ТС]
это часть тг бота для заказа справок из отдела кадров

Добавлено через 1 минуту
если нужен полный код могу скинуть я пишу на вижуал студии 2022 года не понимаю толи деректив не хватает толи просто неправильно написал
0
Эксперт .NET
 Аватар для Wolfdp
3790 / 1767 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
09.12.2025, 17:04
mashasokol.soko, дєбажить код умеете?
0
0 / 0 / 0
Регистрация: 09.12.2025
Сообщений: 3
09.12.2025, 17:05  [ТС]
нет
0
 Аватар для XIST
1962 / 1072 / 148
Регистрация: 01.10.2009
Сообщений: 3,620
Записей в блоге: 1
09.12.2025, 17:26
mashasokol.soko, я бы тоукен убрал с сообщения
0
09.12.2025, 17:29

Не по теме:

Убрал токен

0
Эксперт .NET
 Аватар для Wolfdp
3790 / 1767 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
09.12.2025, 18:48
mashasokol.soko, самое время почитать что такое дебаг (она же "отладка") и применить на практике.

отдельно замечу что async void Bot_OnMessage скорее всего неправильно. Либо метод должен возвращать Task, либо убирайте асинхроность.

P.S. если ошибка компиляции (приложение в принципе не собирается), то не плохо бы закинуть на форум это самое сообщение об ошибке. (а ещё лучше таки его прочитать, обычно там сразу понятно что не так)
0
 Аватар для Calabonga
14 / 13 / 1
Регистрация: 13.02.2025
Сообщений: 34
10.12.2025, 05:22
Цитата Сообщение от Wolfdp Посмотреть сообщение
отдельно замечу что async void Bot_OnMessage скорее всего неправильно. Либо метод должен возвращать Task, либо убирайте асинхроность.
Либо try...catch на тело метода.
0
2395 / 1925 / 763
Регистрация: 27.07.2012
Сообщений: 5,569
10.12.2025, 09:13
Цитата Сообщение от mashasokol.soko Посмотреть сообщение
C#
1
await StartCommand(message);
Подозреваю, что у ТС типичная ошибка новичков, работающих с этим бот-апи. В StartMessage находится вся логика диалога с пользователем. Фактически же здесь будут обрабатываться только сообщения "/start", а остальные - мимо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.12.2025, 09:13
Помогаю со студенческими работами здесь

не работает [If (Request.QueryString('Submit') = 'Оформить заказ') ],т.е. Request.QueryString('Submit') не выдает значение.
Помогите ,пожалуйста!!!!!!! Я только учусь ASP есть у меня проблема в том,что не работает ,т.е. ...

Хранение корзины заказов в Cookie
Добрый день! Собственно сабж. Знаю,что это плохо, лучше хранить в сессиях, бд и т.д, но сейчас...

Хранение товаров в корзине до оформления заказа
Доброго времени суток. Не знаю насколько правильно я выбрал ветку форума, если ошибся прошу...

Какие задачи чаще всего приходиться выполнять относительно требований заказчиков на ASP.NET?
Здравствуйте, вопрос немного другого рода. Хотелось бы узнать у специалистов, какие задачи чаще...

Правильное использование Redirect при отправке заказа
Добрый день! Подскажите, как правильно использовать Redirect при нажатии на кнопке отправки...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru