0 / 0 / 0
Регистрация: 09.12.2025
Сообщений: 3
Telegram Bot

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

09.12.2025, 15:37. Показов 501. Ответов 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
87827 / 53148 / 249
Регистрация: 10.04.2006
Сообщений: 13,761
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
1960 / 1070 / 148
Регистрация: 01.10.2009
Сообщений: 3,590
Записей в блоге: 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
Сообщений: 33
10.12.2025, 05:22
Цитата Сообщение от Wolfdp Посмотреть сообщение
отдельно замечу что async void Bot_OnMessage скорее всего неправильно. Либо метод должен возвращать Task, либо убирайте асинхроность.
Либо try...catch на тело метода.
0
2393 / 1914 / 763
Регистрация: 27.07.2012
Сообщений: 5,559
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru