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

Подскажите как в этот код добавить строки в которых можно буквы сообщения на англ заменить их порядковым номером

11.11.2023, 04:47. Показов 450. Ответов 4

Студворк — интернет-сервис помощи студентам
Visual Basic
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
Private n As Long 
'исходный алфавит
Const АБВ As String = "abcdefghijklmnopqrstuvwxyz" 
'новый алфавит
Const НовАБВ As String = "яюэьыъщшчцхфутсрпонмлкйизжедгвба" 
Private Sub AnotherCipher()
Dim STR As String, strT As String, strR As String 
‘строка которую будем зашифровывать
STR = "Простая замена один из самых древних шифров"
 ‘ переход к нижнему регистру
STR = LCase(STR)
‘печать в окно Immediate 
Debug.Print STR
' шифровка
 
Decode STR, strR, АБВ, НовАБВ 
Debug.Print strR
'расшифровка
Decode strR, strT, НовАБВ, АБВ 
Debug.Print strT
Private Sub Decode(STR, STRS, Oldkey, NewKey) 
Dim n As Long, i As Long
Dim tmp As String
'определяем количество символов исходной строки 
n = Len(STR)
'вводим преобразованную строку, состоящую из n пробелов 
STRS = Space(n)
For i = 1 To n
'выделяем один символ исходной строки 
tmp = Mid(STR, i, 1)
'определяем место символа исходной строки в исходном алфавите 
k = InStr(1, Oldkey, tmp)
If k = 0 Then
'если в исходном алфавите такого символа нет 'то переносим его в новую строку не изменяя 
Mid(STRS, i, 1) = tmp
Else
'заменяем соответствующий пробел на символ нового алфавита
 Mid(STRS, i, 1) = Mid(NewKey, k, 1)
End If 
Next i
 End Sub
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.11.2023, 04:47
Ответы с готовыми решениями:

В матрице заменить буквы их порядковым номером
Дано NxN две матрицы, одна из символов одна из цифр. Например вот так : a b c //a=1 b=2 c=3 d e f //d=4 e=5...

В матрице минимальные элементы каждой строки заменить порядковым номером элемента в строке
В модульной программе выдает ошибку 3,перед vivod хотя я его и описала,не могу исправить,помогите: uses crt,modull; var a:matr; ...

Заменить каждый символ текста его порядковым номером в таблице ASCII, преобразованным в двоичный код
Здравствуйте помогите пожалуйста Закодировать и раскодировать текст по следующему правилу: заменить каждый символ его порядковым номером...

4
Заблокирован
11.11.2023, 08:29
Visual Basic
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
Private n As Long
'исходный алфавит
Const АБВ As String = "abcdefghijklmnopqrstuvwxyz"
'новый алфавит
Const НовАБВ As String = "яюэьыъщшчцхфутсрпонмлкйизжедгвба"
 
Private Sub AnotherCipher()
    Dim STR As String, strT As String, strR As String
    'строка которую будем зашифровывать
    STR = "Простая замена один из самых древних шифров"
    ' переход к нижнему регистру
    STR = LCase(STR)
    'печать в окно Immediate
    Debug.Print STR
    ' шифровка
    Decode STR, strR, АБВ, НовАБВ
    Debug.Print strR
    'расшифровка
    Decode strR, strT, НовАБВ, АБВ
    Debug.Print strT
End Sub
 
Private Sub Decode(STR, STRS, Oldkey, NewKey)
    Dim n As Long, i As Long
    Dim tmp As String
    'определяем количество символов исходной строки
    n = Len(STR)
    'вводим преобразованную строку, состоящую из n пробелов
    STRS = Space(n)
    For i = 1 To n
        'выделяем один символ исходной строки
        tmp = Mid(STR, i, 1)
        'определяем место символа исходной строки в исходном алфавите
        k = InStr(1, Oldkey, tmp)
        If k = 0 Then
            'если в исходном алфавите такого символа нет 'то переносим его в новую строку не изменяя
            Mid(STRS, i, 1) = tmp
        Else
            'заменяем соответствующий пробел на порядковый номер буквы в алфавите
            Mid(STRS, i, 1) = CStr(Asc(Mid(STR, i, 1)) - 96)
        End If
    Next i
End Sub
1
1389 / 845 / 92
Регистрация: 08.02.2017
Сообщений: 3,599
Записей в блоге: 1
11.11.2023, 09:40
Цитата Сообщение от mojors Посмотреть сообщение
Подскажите как в этот код добавить строки в которых можно буквы сообщения на англ заменить их порядковым номером
Для этого надо хоть немного соображать, а раз не соображаете, я размещую ответ очень мелким невидимым шрифтом
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Sub kkhjlyuyh()
    Dim s1$, s2$
    s1 = "jyuhgyWEeRRFX"
    s2 = charToABNum(s1)
End Sub
Function charToABNum(s1 As String) As String
    Dim s2$, i&, sn$, ln&, crsr&
    s1 = UCase(s1)
    s2 = String$(1000, vbNullChar)
    crsr = 1
    For i = 1 To Len(UCase(s1))
        sn$ = Asc(Mid$(s1, i, 1)) - 64
        ln = Len(sn)
        Mid$(s2, crsr, ln) = sn
        crsr = crsr + ln
    Next
    charToABNum = Mid$(s2, 1, crsr - 1)
End Function
0
Эксперт MS Access
 Аватар для Eugene-LS
13181 / 5879 / 1506
Регистрация: 05.10.2016
Сообщений: 16,505
11.11.2023, 11:00
Цитата Сообщение от testuser2 Посмотреть сообщение
... мелким невидимым шрифтом
For i = 1 To Len(UCase(s1))
Улыбнуло!
Спасибо.
0
665 / 334 / 135
Регистрация: 16.07.2020
Сообщений: 957
11.11.2023, 12:06
Цитата Сообщение от mojors Посмотреть сообщение
буквы сообщения на англ заменить их порядковым номером
Можно так закодировать, но раскодировать не получится. Как, например, понимать последовательность 12, это могут быть буквы ab, или буква l.
Предполагаю, что буквы для замены нужно искать в константе АБВ с учетом регистра, а не в таблице кодов виндвс, чтобы иметь возможность легко изменять кодировку.
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Option Explicit
Const АБВ As String = "abcdefghijklmnopqrstuvwxyz"
Function Cod(Stroka As String) As String
  Dim i%
  For i = 1 To Len(Stroka)
    If InStr(1, АБВ, Mid(Stroka, i, 1)) > 0 Then
      Cod = Cod & InStr(1, АБВ, Mid(Stroka, i, 1))
      'Cod = Cod & InStr(1, АБВ, Mid(Stroka, i, 1)) + 9 'К порядковому номеру прибавляем 9
      'Cod = Cod & IIf(InStr(1, АБВ, Mid(Stroka, i, 1)) > 9, _
      'InStr(1, АБВ, Mid(Stroka, i, 1)), 0 & InStr(1, АБВ, Mid(Stroka, i, 1))) 'Номера в двухзначном виде
    Else
      Cod = Cod & Mid(Stroka, i, 1)
    End If
  Next
End Function
В таком виде функция выдаст то, что вы хотите, т.е. нераскодируемую строку. Предлагаю 2 варианта сделать строку раскодируемой.
1. Прибавить к порядковому номеру 9, нумерация начнется с числа 10. Нужно закомментировать строку 7 и раскомментировать строку 8.
2. Порядковые номера записывать в двухзначном виде, типа 01, 03. Тогда закомментировать строку 7 и раскомментировать строки 9 и 10.
Правда остается еще вопрос. Если в исходном тексте будут цифры, то раскодировать будет невозможно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.11.2023, 12:06
Помогаю со студенческими работами здесь

Подскажите как этот код можно переписать в if, else
let toggleBtn = document.querySelector('.toggle_btn'); let dropMenu = document.querySelector('.drop_menu'); let toggleBtnIcon =...

Подскажите как можно упростить этот код
Const isDebugMode = True Const newNameSh = "CRMds" Const ourBook = "___CRnnnn_QA Estimation Evaluation_JIRA_YYYYMMDDVersion1.0.xlsm" ...

Заменить порядковым номером
В матрице А (mxn) минимальные элементы каждой строки заменить порядковым номером этого элемента в строке.

Можно добавить в этот код, так чтобы фамилии выскакивали повторяющиеся?(КАК?)
Private Sub TextBox2_Change() AddItem "Ветрова Ксения Сергеевна" AddItem "Хуриганова Маргарита Иванова" AddItem "Софьина...

Точки заменить их порядковым номером
Задание звучит так: заменить все точки цифрами, с соответствующими им номерами. Написал этот код. Но тут проверка уже на самом выводе....


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита табличной части. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru