С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.59/32: Рейтинг темы: голосов - 32, средняя оценка - 4.59
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012

[Программа] Проверка баланса (Ростелеком)

24.08.2013, 19:40. Показов 6864. Ответов 26
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Начну с того, что бОльшая часть полезного кода (получение данных из "нового личного кабинета") была написана bhswat'ом, за что ему отдельное огромное спасибо. Я лишь довел утилиту до ума и "придал ей человеческий вид".
Работоспособность утилиты проверялась на Тульской области. Также доступны другие "центральные" регионы (portal.center.rt.ru).
Логин/пароль хранятся в шифрованном виде (текстовый файл settings.txt в директории программы).
В исходниках соответствующие функции (code и decode) заменены "заглушками" из очевидных соображений.
Программа использует две библиотеки (libeay32.dll и ssleay32.dll), находятся в архиве, должны располагаться в одной папке с ехе-шником.
Для "парсинга" используются регулярные выражения.
Реализован альтернативный выбор региона (в виде карты), для этого нужно кликнуть на логотип "Ростелеком". Задача вроде нетривиальная, но решение достаточно простое (используется проверка цветовых кодов). Иногда "глючит" из-за местами неравномерного распределения цвета (спишем на мою "криворукость" в техническом плане "при оформлении картинки", я не дизайнер и тем более не художник; в качестве оправдания могу лишь сказать, что "это Paint так заливку цветом сделал").

ехе + dll: http://www.mediafire.com/downl... hecker.zip
исходники: http://www.mediafire.com/downl... Source.zip
IDE: Builder 2007.
P.S.: третий скрин - анализ того, что и куда передается (для тех, кто опасается передачи данных "налево").
Миниатюры
[Программа] Проверка баланса (Ростелеком)   [Программа] Проверка баланса (Ростелеком)   [Программа] Проверка баланса (Ростелеком)  

2
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.08.2013, 19:40
Ответы с готовыми решениями:

Проверка баланса
Привет! У меня есть такой код: <form method="post" action="miner.php"> <h2><p>Введите ставку</p><h2> ...

Проверка баланса скобок
У меня есть вот такой код, но я не могу понять как он работает, не могли бы вы помочь мне с этим, расставив комменты? Буду очень благодарен...

Проверка баланса скобок
#include<stdio.h> #include<string.h> struct NODE { char info; NODE *next; }; struct STACK {

26
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012
10.10.2015, 00:00  [ТС]
Студворк — интернет-сервис помощи студентам
Зачем?
0
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012
19.05.2016, 19:26  [ТС]
Выкладываю последнюю версию с исходниками.
Что-то сайт стал долго отдавать информацию по стоимости тарифного плана.
Но уже запустили бета-версию нового личного кабинета. Когда будет работать в нормальном режиме, постараюсь переделать программу под него.
Миниатюры
[Программа] Проверка баланса (Ростелеком)  
Вложения
Тип файла: zip balance_checker.zip (2.73 Мб, 3 просмотров)
1
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012
13.07.2016, 20:56  [ТС]
Подправил отображение стоимости тарифного плана. Программа во вложении. Добавил пару библиотек ssleay32.dll и libeay32.dll (иначе у некоторых пользователей могли выскакивать ошибки - видимо, иногда работа с https требует наличия на произвольном компьютере доп. файлов).

Заодно задам вопрос. Надеюсь также на помощь volvo.
В новой версии личного кабинета (моего провайдера) данные при запросе и ответе передаются в формате JSON.



Могу ли я отправлять данные (при запросе) в обычном "текстовом" виде, минуя работу напрямую с JSON?
В режиме "Data" HTTP Analyzer показывает данные в таком виде
Code
1
{"login":"my_login","loginType":"LOGIN","passwd":"my_pass","remember":true,"client_uuid":"my_uid"}


P.S.: я конечно мог бы просто взять и проверить, но лучше сначала убедиться в правильности (или возможности) способа.
Либо понять, как это нужно обычно делать.
Вложения
Тип файла: zip balance_checker.zip (3.47 Мб, 7 просмотров)
0
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012
14.07.2016, 17:06  [ТС]
Сделал программу для нового личного кабинета (ЛК). Старый ЛК, возможно, в дальнейшем "поддерживать" не буду.
Убрал лишний код, существующий немного оптимизировал.
Так как сайт сделан людьми с руками и передаются в основном только нужные данные, то получение информации существенно ускорилось.



cpp (форум убирает экранирование двойных кавычек " с помощью обратного слеша \):
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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
 
TIdHTTP *HTTP = new TIdHTTP(NULL);
TMemoryStream *MS  = new TMemoryStream;
TIdSSLIOHandlerSocketOpenSSL *ssl = new TIdSSLIOHandlerSocketOpenSSL(NULL);
TStringList *SL = new TStringList;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
    : TForm(Owner)
{
  HTTP->HandleRedirects = 1;
  HTTP->IOHandler = ssl;
}
//---------------------------------------------------------------------------
// https://www.cyberforum.ru/cpp-builder/thread984048.html
int BitCount = 8;
String MyIntToBin(unsigned char In)
{
  int BitCount = 8;
  String Result("", BitCount);
  for(int i = BitCount, Mask = 1; i > 0; i--, Mask <<= 1)
    {
      if(In & Mask)
        Result[i] = '1';
      else
        Result[i] = '0';
    }
  return Result;
}
//---------------------------------------------------------------------------
unsigned char MyBinToInt(String In)
{
  unsigned int Result = 0, Mult = 1;
  for(int i = BitCount; i > 0; i--)
  {
    Result += StrToInt(In[i]) * Mult;
    Mult *= 2;
  }
  return (unsigned char)Result;
}
//---------------------------------------------------------------------------
String salt1, salt2;
void TForm1::gen_salt()
{
  int i;
  salt1 = "";
  salt2 = "";
  for (i = 1; i <= Login->Text.Length() * BitCount; i++)
    salt1 += random(2);
  for (i = 1; i <= Password->Text.Length() * BitCount; i++)
    salt2 += random(2);
}
//---------------------------------------------------------------------------
String code(String text, String salt)
{
  String result = "", code = "";
  int i;
 
  for (i = 1; i <= text.Length(); i++)
    result += MyIntToBin(text[i]);  // перевод исходной строки в двоичный вид
 
  randomize();
  for (i = 1; i <= result.Length(); i++)
    salt[i] == result[i] ? code += "0" : code += "1";  // шифрование XOR
 
  return code;
}
//---------------------------------------------------------------------------
String decode(String code, String salt)
{
  String result = "", text = "";
  int i;
 
  for (i = 1; i <= code.Length(); i++)
    salt[i] == code[i] ? result += "0" : result += "1";  // дешифрование XOR
 
  text.SetLength(code.Length()/BitCount);
  for (i = 1; i <= code.Length(); i += BitCount)
    text[i/BitCount+1] = MyBinToInt(result.SubString(i, BitCount));  // перевод двоичной строки в исходный вид
 
  return text;
}
//---------------------------------------------------------------------------
String TForm1::DataSearch(TMemo *Memo, String from, String to, bool cont, int inc)
{
  int i, PosReturn, dif;
  for (i = 0; i < Memo->Lines->Count; i++)
  {
    PosReturn = Memo->Lines->Strings[i].Pos(from);
    if (PosReturn)
      break;
  }
  dif = cont ? Memo->Lines->Strings[i+inc].Pos(to) + to.Length() : 1;
  String temp = Memo->Lines->Strings[i+inc].SubString(dif, Memo->Lines->Strings[i+inc].Length()-dif+1);
  return MidStr(temp, temp.Pos(from)+from.Length(), temp.Pos(to)-temp.Pos(from)-from.Length());
}
//---------------------------------------------------------------------------
String GetUUID()
{
  // генерация uuid, например (как вариант), 998A0BCC-EC31-4187-881E-1A1CAC90EB64
  // если лень, то можно просто написать
  // uuid = "998A0BCC-EC31-4187-881E-1A1CAC90EB64";
  // а можно и не писать
  String symbols = "0123456789ABCDEF", uuid = "";
  const delimiters_count = 4, uuid_length = 36;
  char delimiter_char = '-';
  bool is_delimiter;
  int i, j, delimiter_pos[delimiters_count] = {9, 14, 19, 24}, symbols_length = symbols.Length();
  randomize();
  for (i = 1; i <= uuid_length; i++)
  {
    is_delimiter = 0;
    for (j = 0; j < delimiters_count; j++)
      if (i == delimiter_pos[j])
      {
        uuid += delimiter_char;
        is_delimiter = 1;
        break;
      }
    if (!is_delimiter)
      uuid += symbols[random(symbols_length)+1];
  }
  return uuid;
}
//---------------------------------------------------------------------------
void TForm1::GetData(String request, String site)
{
  MS->Clear();
  SL->Clear();
  SL->Add(request);
  HTTP->Post(site, SL, MS);
  MS->Position = 0;
  SL->LoadFromStream(MS);
  Memo->Text = UTF8ToString(SL->Text);
}
//---------------------------------------------------------------------------
String title = "Проверка баланса (lk-new.rt.ru)";
void __fastcall TForm1::logonClick(TObject *Sender)
{
  DWORD start;
  Caption = title;
  sets->Click();
  start = GetTickCount();
 
  try
  {
    Timer->Enabled = 1;
 
    for (int i = 0; i < 5; i++)
      ValueListEditor->Strings->ValueFromIndex[i] = " ";
 
    String s1, s2, temp = "", request, site;
    Login->Text = Trim(Login->Text);
    Password->Text = Trim(Password->Text);
    if ((Login->Text != "") && (Password->Text != ""))
    {
    HTTP->Request->Accept = "application/json, text/javascript, */*; q=0.01";
    HTTP->Request->UserAgent = "Mozilla/5.0 (Windows NT 6.1; rv:47.0) Gecko/20100101 Firefox/47.0";
    HTTP->Request->ContentType = "application/json";
    HTTP->Request->AcceptLanguage = "ru-RU,ru;q=0.8,en-US;q=0.5,en;q=0.3";
    HTTP->Request->AcceptEncoding = "gzip, deflate, br";
    HTTP->Request->CustomHeaders->AddValue("X-Requested-With", "XMLHttpRequest");
    request = "{"login":"" + Login->Text + "","loginType":"LOGIN","passwd":"" + Password->Text + "","remember":true,"client_uuid":"" + GetUUID() + ""}";
    site = "https://lk-new.rt.ru/client-api/login";
    GetData(request, site);
 
    s1 = "sessionKey":"", s2 = "","userLogin";
    temp = DataSearch(Memo, s1, s2, 0, 0);
 
    if (temp == "")
      MessageBox(Application->Handle, "Возможно, неправильно введен логин или пароль.", "Ошибка", MB_OK+MB_ICONWARNING);
    }
 
    if (temp != "")  // нет ошибок
      if ((Login->Text != "") && (Password->Text != ""))
    {
    HTTP->Request->CustomHeaders->AddValue("Cookie", "sessionKey=" + temp);
    request = "{"client_uuid":"" + GetUUID() + ""}";
    site = "https://lk-new.rt.ru/client-api/getProfile";
    GetData(request, site);
 
    s1 = "lastName":"", s2 = "","name";
    temp = " " + DataSearch(Memo, s1, s2, 0, 0);  // фамилия
    s1 = "name":"", s2 = "","middleName";
    temp += " " + DataSearch(Memo, s1, s2, 0, 0);  // имя
    s1 = "middleName":"", s2 = "","birthday";
    temp += " " + DataSearch(Memo, s1, s2, 0, 0);  // отчество
    ValueListEditor->Strings->ValueFromIndex[1] = temp;  // ФИО
 
 
    request = "{"client_uuid":"" + GetUUID() + ""}";
    site = "https://lk-new.rt.ru/client-api/getAccounts";
    GetData(request, site);
 
    s1 = "oldNumber":"", s2 = "","trustLevel";
    temp = DataSearch(Memo, s1, s2, 0, 0);  // oldNumber
    ValueListEditor->Strings->ValueFromIndex[0] = " " + temp + (temp == "" ? "услуга не привязана / отсутствует" : "");  // лицевой счет
    s1 = "number":"", s2 = "","oldNumber";
    temp = DataSearch(Memo, s1, s2, 0, 0);  // newNumber
    ValueListEditor->Strings->ValueFromIndex[0] = " " + temp + " (new) /" + ValueListEditor->Strings->ValueFromIndex[0] + " (old)";
    s1 = "displayNumber":"", s2 = "","serviceDuty";
    ValueListEditor->Strings->ValueFromIndex[4] = " " + DataSearch(Memo, s1, s2, 0, 0);  // логин
 
    String accountId, serviceId;
    s1 = "accountId":", s2 = ","number";
    accountId = DataSearch(Memo, s1, s2, 0, 0);
    s1 = "serviceId":", s2 = ","number";
    serviceId = DataSearch(Memo, s1, s2, 1, 0);
 
 
    request = "{"accountId":" + accountId + ","client_uuid":"" + GetUUID() + ""}";
    site = "https://lk-new.rt.ru/client-api/getAccountBalance";
    GetData(request, site);
 
    s1 = "balance":", s2 = ","subAccounts";  // баланс
    ValueListEditor->Strings->ValueFromIndex[2] = " " + String(StrToInt64Def(DataSearch(Memo, s1, s2, 0, 0), 0)/100.) + " руб.";
 
 
    request = "{"serviceId":" + serviceId + ","client_uuid":"" + GetUUID() + ""}";
    site = "https://lk-new.rt.ru/client-api/getServiceTariff";
    GetData(request, site);
 
    s1 = "name":"", s2 = "","description";  // тарифный план
    temp = " " + DataSearch(Memo, s1, s2, 0, 0);
 
    s1 = "fee":", s2 = ","isAction";  // стоимость услуги / тарифного плана
    temp += " - " + String(StrToInt64Def(DataSearch(Memo, s1, s2, 0, 0), 0)/100.) + " руб./месяц";
    ValueListEditor->Strings->ValueFromIndex[3] = temp;
    }
 
    Timer->Enabled = 0;
    Caption = title + "   : : : : :   " + FloatToStr((GetTickCount()-start)/1000.) + " секунд";
 
    ValueListEditor->Row = 3;
  }
  catch (EIdException &E)
  {
    Timer->Enabled = 0;
    Caption = title + "   : : : : :   " + FloatToStr((GetTickCount()-start)/1000.) + " секунд";
    MessageBox(Application->Handle, AnsiString("""+E.Message+""\n\nВозможно, отсутствует подключение\nк интернету или нет доступа к сайту.").c_str(), "Ошибка", MB_OK+MB_ICONWARNING);
  }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::setsClick(TObject *Sender)
{
  String settings = ExtractFilePath(ParamStr(0)) + "settings.txt";
  if (FileExists(settings))
    DeleteFile(settings);
 
  if (save->Checked)
  {
    gen_salt();
    if (Trim(Login->Text) != "")
      options->Strings->ValueFromIndex[0] = code(Login->Text, salt1);
    if (Trim(Password->Text) != "")
      options->Strings->ValueFromIndex[1] = code(Password->Text, salt2);
    options->Strings->ValueFromIndex[2] = "1";
    if (auto_enter->Checked)
      options->Strings->ValueFromIndex[3] = "1";
    else
      options->Strings->ValueFromIndex[3] = "0";
    options->Strings->ValueFromIndex[4] = salt1;
    options->Strings->ValueFromIndex[5] = salt2;
    options->Strings->SaveToFile(settings);
  }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::FormShow(TObject *Sender)
{
  String settings = ExtractFilePath(ParamStr(0)) + "settings.txt";
  if (FileExists(settings))
  {
    salt1 = "", salt2 = "";
    options->Strings->LoadFromFile(settings);
    if (options->Strings->ValueFromIndex[2] == "1")
    {
      salt1 = options->Strings->ValueFromIndex[4];
      salt2 = options->Strings->ValueFromIndex[5];
      logon->SetFocus();
      Login->Text = decode(options->Strings->ValueFromIndex[0], salt1);
      Password->Text = decode(options->Strings->ValueFromIndex[1], salt2);
      save->Checked = 1;
      if (options->Strings->ValueFromIndex[3] == "1")
      {
        auto_enter->Checked = 1;
        logon->Click();
      }
//    else
//          auto_enter->Checked = 0;
 
    }
    save->OnClick;
  }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::exitClick(TObject *Sender)
{
  delete MS;
  delete SL;
  delete ssl;
  delete HTTP;
 
  Close();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::saveClick(TObject *Sender)
{
  if (save->Checked)
    auto_enter->Visible = 1;
  else
    auto_enter->Visible = 0;
}
//---------------------------------------------------------------------------
void __fastcall TForm1::FormClose(TObject *Sender, TCloseAction &Action)
{
  String settings = ExtractFilePath(ParamStr(0)) + "settings.txt";
  if (FileExists(settings))
    if (save->Checked)
    {
      if (auto_enter->Checked)
        options->Strings->ValueFromIndex[3] = "1";
      else
        options->Strings->ValueFromIndex[3] = "0";
      options->Strings->SaveToFile(settings);
    }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::BitBtnClick(TObject *Sender)
{
  if (Password->PasswordChar == '*')
    Password->PasswordChar = NULL;
  else
    Password->PasswordChar = '*';
}
//---------------------------------------------------------------------------
void __fastcall TForm1::TimerTimer(TObject *Sender)
{
  String symbols = "01", temp = "";
  const temp_length = 30;
  int i, j, symbols_length = symbols.Length();
  randomize();
  for (i = 1; i <= temp_length; i++)
    temp += symbols[random(symbols_length)+1];
 
  Caption = title + "   : : : : :   " + temp;
}
//---------------------------------------------------------------------------
h:
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
//---------------------------------------------------------------------------
 
#ifndef Unit1H
#define Unit1H
//---------------------------------------------------------------------------
#include <System.Classes.hpp>
#include <Vcl.Controls.hpp>
#include <Vcl.StdCtrls.hpp>
#include <Vcl.Forms.hpp>
#include <Vcl.ComCtrls.hpp>
#include <Vcl.ExtCtrls.hpp>
#include <Vcl.Grids.hpp>
#include <Vcl.ValEdit.hpp>
#include <StrUtils.hpp>
#include <IdHTTP.hpp>
#include <IdSSLOpenSSL.hpp>
#include <Vcl.Buttons.hpp>
#include <Vcl.Imaging.pngimage.hpp>
#include <IdAntiFreezeBase.hpp>
#include <IdBaseComponent.hpp>
#include <Vcl.IdAntiFreeze.hpp>
//---------------------------------------------------------------------------
class TForm1 : public TForm
{
__published:    // IDE-managed Components
    TImage *Image1;
    TButton *sets;
    TGroupBox *GroupBox1;
    TLabeledEdit *Login;
    TLabeledEdit *Password;
    TButton *logon;
    TCheckBox *save;
    TGroupBox *GroupBox2;
    TValueListEditor *ValueListEditor;
    TValueListEditor *options;
    TButton *exit;
    TCheckBox *auto_enter;
    TMemo *Memo;
    TBitBtn *BitBtn;
    TIdAntiFreeze *IdAntiFreeze;
    TTimer *Timer;
    void __fastcall logonClick(TObject *Sender);
    void __fastcall setsClick(TObject *Sender);
    void __fastcall FormShow(TObject *Sender);
    void __fastcall exitClick(TObject *Sender);
    void __fastcall saveClick(TObject *Sender);
    void __fastcall FormClose(TObject *Sender, TCloseAction &Action);
    void __fastcall BitBtnClick(TObject *Sender);
    void __fastcall TimerTimer(TObject *Sender);
private:    // User declarations
public:     // User declarations
    __fastcall TForm1(TComponent* Owner);
    void gen_salt();
    String DataSearch(TMemo *Memo, String from, String to, bool cont, int inc);
    void GetData(String request, String site);
};
//---------------------------------------------------------------------------
extern PACKAGE TForm1 *Form1;
//---------------------------------------------------------------------------
#endif
Исходники с ехе прилагаются.
Вложения
Тип файла: zip balance_checker_new.zip (3.47 Мб, 11 просмотров)
0
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012
18.08.2016, 20:18  [ТС]
Чтобы каждый раз не выкладывать новые версии, решил "залить" программу на файлообменник с постоянной ссылкой.
Все обновления будут доступны здесь: http://www.mediafire.com/downl... er_new.zip
0
Эксперт С++
 Аватар для Avazart
8484 / 6151 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
18.08.2016, 22:16
githab или банально в блог выложить?
0
place status here
 Аватар для gunslinger
3186 / 2220 / 640
Регистрация: 20.07.2013
Сообщений: 6,012
18.08.2016, 22:35  [ТС]
github-ом не пользуюсь, а в блог можно потом, лень пока оформлять.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.08.2016, 22:35
Помогаю со студенческими работами здесь

Проверка баланса скобок
Здравствуйте! Помогите пожалуйста со следующей задачкой. Необходимо написать код с помощью регулярных выражений и без них для удаления из...

Проверка баланса скобок
Как задать условие в проверке баланса скобок, что если скобки окажутся НЕ пустыми, тое сть внутри них еще что-то будет (символы или ...

Проверка баланса на мтс коммуникаторе
&amp;НаСервере Функция ПолучитьБалансАккаунтаSMS(ВыдаватьСообщенияОбОшибке = Истина) Экспорт Результат = Новый Структура(&quot;Баланс,...

Проверка баланса расстановки скобок
Разработать и испытать функцию для проверки баланса парных скобок в строке, то есть количество открытых скобок должно совпадать с...

Проверка баланса активных мощностей
Добрый день. Интересует формула по которой можно проверить баланс мощностей - активных Такая подойдёт? Pист. = U*I Или это...


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

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
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. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru