Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
8 / 8 / 3
Регистрация: 01.05.2014
Сообщений: 14

Определить сумму программистов

01.05.2014, 16:11. Показов 1332. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В общем есть задание где нужно подсчитать общее количество программистов пример есть текст в тексте может встречаться слово сочетания 1 программист, 4 программистА, 20 программистОВ нужно вывести найдено программистов 25.

Условие чтобы не было не каких textbox-тов была 1 кнопка для выбора txt файла.

Я сделал программу которая подсчитывает программистов если тока они в столбик пример

1 программист
4 программиста
20 программистов


Кликните здесь для просмотра всего текста
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
44
45
46
47
48
49
50
Dim Adres As String
 
Private Sub Command1_Click()
 
    Dim MyText As String
    Dim Result As String
 
On Error GoTo error
    
    With CommonDialog
    
        Command1.Enabled = False
                
        .CancelError = True
        .InitDir = "C:\"
        .Filter = "Текстовый файл |*.txt"
        .FileName = Empty
        .ShowOpen
        
        Adres = .FileName ' запоменаем путь к файлу
        OpenFile ' открываем выбрайный файл
 
    End With
    
error:
    Command1.Enabled = True
End Sub
 
Public Function OpenFile()
 
    Dim MyArray() As String
    Dim Result As String
    Dim MyTXT As String
    Dim a, c As Long
        
    Open Adres For Input As #1 'Открываем выбранный файл
        Do Until EOF(1)
        
            Input #1, MyTXT ' Задаём в переменную 1-ю строчку текста
            
            MyArray() = Split(LCase(MyTXT), "программист") 'отбрасываем слово программист(а)(ов)(ы) оставляем только число
            a = Trim(MyArray(0)) 'запоминаем в переменую число и удаляем со всех сторон пробелы
            c = Val(a) + Val(c) 'Ну и суммируем найденные количества
        
        Loop
    Close #1
    
    MsgBox "Общее количество программистов = " & c, vbInformation + vbOKOnly, "Поиск" 'Выводим общее количество
    
End Function



Но это не устраивает, так как программисты могут быть и в столбик и в строчку и может встречать посторонний текст

Помогите пожалуйста как сделать чтобы программа определяя что перед словом программист есть число.

p.s. Не обязательно писать весь код, хотя бы куда копать в каком направлении
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.05.2014, 16:11
Ответы с готовыми решениями:

Ищу программистов Cocos2d-x для разработки игр, Ищу программистов C++
Привет всем. Ищу разработчиков С++ для мобильной игры (iOS, Android и WP в перспективе). Используемый движок - Cocos2d-x. Сейчас в...

Определить сумму, произведение и сумму квадратов всех элементов массива.
Определить: Сумму всех элементов массива; произведение всех элементов массива; сумму квадрата всех элементов массива.

Определить и вывести на экран сумму четных и сумму нечетных элементов
создать массив, содержащий 8 целых чисел. Определить и вывести на экран сумму четных и сумму нечетных элементов

6
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
01.05.2014, 17:05
Лучший ответ Сообщение было отмечено Jason2033 как решение

Решение

Jason2033, как вариант
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Public Function OpenFile()
 Dim x, c As Long
 x = CreateObject("scripting.filesystemobject").opentextfile(Adres).readall
 With CreateObject("vbscript.regexp")
    .Pattern = "(\d+)\s*программист"
    .Global = True
    .ignorecase = True
    For Each x In .Execute(x)
      c = c + x.submatches(0)
    Next
 End With
 MsgBox "Общее количество программистов = " & c, vbInformation + vbOKOnly, "Поиск" 'Выводим общее количество
End Function
Между числом и словом может быть любое число пробелов (или не одного), переводы строки, табуляция.
1
8 / 8 / 3
Регистрация: 01.05.2014
Сообщений: 14
01.05.2014, 17:15  [ТС]
Казанский, да ты гений.

Между числом и словом может быть только пробел Пример: любой текст 4897897894765 программистов любой текст

спс за код но блин как всё это работает что это такое

Visual Basic
1
2
3
4
5
 x = CreateObject("scripting.filesystemobject").opentextfile(Adres).readall
 With CreateObject("vbscript.regexp")
    .Pattern = "(\d+)\s*программист"
    .Global = True
    .ignorecase = True
0
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
01.05.2014, 17:27
Цитата Сообщение от Jason2033 Посмотреть сообщение
как всё это работает что это такое
http://www.script-coding.com/W... bject.html
http://www.script-coding.com/WSH/RegExp.html
1
8 / 8 / 3
Регистрация: 01.05.2014
Сообщений: 14
01.05.2014, 18:03  [ТС]
Казанский большое человеческое СПаСИБОООООООО

p.s. просто чтоб знать а это возможно сделать другим способом ???

Добавлено через 34 минуты
Казанский, ещё 1 вопрос я правильно понял этот шаблон
"(\d+)\s*программист" = 0-9 | любой символ | пробел | любой символ | программист
Вот тока не могу понять зачем скобки ?
0
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
01.05.2014, 18:10
Лучший ответ Сообщение было отмечено Jason2033 как решение

Решение

Цитата Сообщение от Jason2033 Посмотреть сообщение
Между числом и словом может быть только пробел
Можно допилить ваш код
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
Public Function OpenFile()
 
    Dim MyArray() As String
    Dim Result As String
    Dim MyTXT As String
    Dim a$, i&, c As Long
        
    Open Adres For Input As #1 'Открываем выбранный файл
        Do Until EOF(1)
        
            Line Input #1, MyTXT ' Задаём в переменную 1-ю строчку текста
            
            MyArray() = Split(LCase(MyTXT), "программист") 'отбрасываем слово программист(а)(ов)(ы) оставляем только число
            For i = 0 To UBound(MyArray) - 1
              
              a = Trim(MyArray(i)) 'запоминаем в переменую число и удаляем со всех сторон пробелы
              If IsNumeric(a) Then
                c = c + a
              Else
                a = Right$(a, Len(a) - InStrRev(a, " "))
                If IsNumeric(a) Then c = c + a
              End If
            Next
        Loop
    Close #1
    
    MsgBox "Общее количество программистов = " & c, vbInformation + vbOKOnly, "Поиск" 'Выводим общее количество
    
End Function
1
8 / 8 / 3
Регистрация: 01.05.2014
Сообщений: 14
01.05.2014, 18:56  [ТС]
Казанский, ещё раз огромно спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.05.2014, 18:56
Помогаю со студенческими работами здесь

Определить сумму квадратов отрицательных элементов матрицы и сумму положительных
1) В массиве данных с1, …,с20 определить сумму квадратов отрицательных элементов и сумму положительных. Подсчитать количество...

Определить сумму положительных и сумму отрицательных элементов матрицы
1. Определить сумму положительных и сумму отрицательных элементов матрицы размерами N*M (N и M не больше 10). Матрицу сформировать из...

Определить сумму, произведение, сумму квадратов элементов массива
Определить:а) сумму всех элементов массива,б) произведение всех элементов массива,с)сумму квадратов весх элементов масива, в)сумму шести...

Определить сумму элементов, стоящих между минимальным и максимальным элементами. Максимальный и минимальный элементы в сумму не включать
Помогиииите!) Определить сумму элементов, стоящих между минимальным и максимальным элементами. Максимальный и минимальный элементы в...

Определить сумму положительных и сумму отрицательных элементов
Дан массив из 12 слов. Определить сумму положительных и сумму отрицательных элементов. Проверить наличие в коде отрицательных элементов 1 в...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru