Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/29: Рейтинг темы: голосов - 29, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 26.10.2020
Сообщений: 12

Количество вхождений слов в строку

15.03.2021, 16:48. Показов 6395. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Столкнулся с такой проблемой: при поиске вхождений слова 'in' в строку засчитываются вхождения и в составе других слов (например Mountain, installs и так далее). Как этого можно избежать?
Пользовался строковым методом count.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.03.2021, 16:48
Ответы с готовыми решениями:

Количество вхождений строки t в строку s
Помогите решить задачки, пожалуйста 3. Вашей программе на вход подаются две строки s и t, состоящие из строчных латинских букв. ...

Узнайте количество вхождений подстроки s2 в строку s3
Не могу понять как делать эти два задания. Остальные смог сделать. s1 = 'Засчитано' s2 = 'Сенсация' s3 =...

Найти количество вхождений подстроки в строку
С клавиатуры вводятца две строки. Найти количество вхождений одной (являющейся подстрокой) в другую.

9
712 / 351 / 120
Регистрация: 09.12.2020
Сообщений: 918
15.03.2021, 16:54
не очень понял вопроса, т. е. вы хотите, чтобы в a = "mountain in installs" (условно) count выдавал 1. Верно?
0
0 / 0 / 0
Регистрация: 26.10.2020
Сообщений: 12
15.03.2021, 16:57  [ТС]
да, все верно
0
102 / 85 / 25
Регистрация: 21.05.2019
Сообщений: 481
15.03.2021, 16:58
Пробелами можно разделить

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
import re
 
string_1 = "qwer wer sdf f df in qwe rewrin wqein in qweds"
start = -1
count = 0
 
while True:
    start = string_1.find(" in ", start + 1)
    if start == -1:
        break
    count += 1
 
print("Количество вхождений символа в строку: ", count)
Или так

Python
1
2
3
4
5
6
import re
 
string_1 = "qwer wer sdf f df in qwe rewrin wqein in" \
           ""
if re.search(r'\bin\b', string_1):
    print("")
0
712 / 351 / 120
Регистрация: 09.12.2020
Сообщений: 918
15.03.2021, 17:07
coloncrusher54, устраивает это решение?
Кликните здесь для просмотра всего текста
Цитата Сообщение от RSAX Посмотреть сообщение
Пробелами можно разделить
PythonВыделить код
1
2
3
4
5
6
7
8
9
10
11
12
13
import re
string_1 = "qwer wer sdf f df in qwe rewrin wqein in qweds"
start = -1
count = 0
while True:
    start = string_1.find(" in ", start + 1)
    if start == -1:
        break
    count += 1
print("Количество вхождений символа в строку: ", count)
Или так
PythonВыделить код
1
2
3
4
5
6
import re
string_1 = "qwer wer sdf f df in qwe rewrin wqein in" \
           ""
if re.search(r'\bin\b', string_1):
    print("")

если нет, могу написапть функцию подходящую к этой задаче
0
0 / 0 / 0
Регистрация: 26.10.2020
Сообщений: 12
15.03.2021, 17:32  [ТС]
Цитата Сообщение от alilxxey Посмотреть сообщение
coloncrusher54, устраивает это решение?
Кликните здесь для просмотра всего текста


если нет, могу написапть функцию подходящую к этой задаче
Пробелами выделять не вариант, слово может стоять в начале\конце. Вообще предложений 22, слов 254. Все это находится в двумерном массиве, слова токенизированны и предложения отделены друг от друга. Нужно посчитать вхождения всех слов в предложения и составить двумерную матрицу 22*254. Все работает правильно, за исключением того, что некоторые слова ошибочно учитываются из-за вхождений в другие слова
0
712 / 351 / 120
Регистрация: 09.12.2020
Сообщений: 918
15.03.2021, 17:38
coloncrusher54,
Цитата Сообщение от coloncrusher54 Посмотреть сообщение
Все работает правильно, за исключением того, что некоторые слова ошибочно учитываются из-за вхождений в другие слова
Попробуйте такой вариант:
1. i = s.find(...)
2. если на s[i - 1] или на s[i + 1 + len(poiskovoye_slovo)] стоит не пробел, то от s.count(..) отнимаем единицу
3. срезаем строку s = s[i + len(poiskovoye_slovo):]

по сути, это то же решение, что и у RSAX, но более понятное и подходяще ИМХО

+ добавьте проверку на то что i не будет out of str range

Надеюсь, поняли

Добавлено через 11 секунд
такое решение подходит?
0
 Аватар для Semen-Semenich
5237 / 3481 / 1176
Регистрация: 21.03.2016
Сообщений: 8,310
15.03.2021, 18:21
Цитата Сообщение от coloncrusher54 Посмотреть сообщение
Пробелами выделять не вариант, слово может стоять в начале\конце
и что?
Python
1
2
3
4
5
6
7
8
9
>>> string_1 = "in qwer wer sdf f df qwe rewrin wqein in qweds in"
>>> print(string_1.split().count('in'))
3
>>> string_1 = "in qwer wer sdf f df qwe rewrin wqein qweds "
>>> print(string_1.split().count('in'))
1
>>> string_1 = "qwer wer sdf f df qwe rewrin wqein qweds in"
>>> print(string_1.split().count('in'))
1
но не прокатит если между in и символом нет пробела
Python
1
2
3
4
>>> string_1 = "qwer wer sdf f df qwe rewrin wqein qweds in?"
>>> print(string_1.split().count('in'))
0
>>>
но тоже можно решить.
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
15.03.2021, 18:31
re.findall чем не устраивает? Одна строчка...
1
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
15.03.2021, 20:17
Python
1
print(len(__import__("re").findall(r"\bin\b", input())))
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.03.2021, 20:17
Помогаю со студенческими работами здесь

Количество вхождений строки T в строку S, повторённую N раз
Гриша уже несколько несколько недель отрабатывает свои навыки в новомодной онлайн-игре про команду космического корабля, вычисляющую...

Подсчитать количество вхождений каждого символа в строку
В тексте все повторяющиеся рядом стоящие символы удалить. Подсчитать количества вхождений каждого символа в строку. Буду очень...

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

Подсчитать количество вхождений слова «мама» в строку и вывести номера первых позиций этих вхождений
Помогите исправить ошибку. Как вывести номера первых позиций вхождений слова мама? Подсчитать количество вхождений слова «мама» в строку...

Определить количество вхождений S3 вхождений в строку S1
Здравствуйте. Помогите, пожалуйста, решить задачу: Ввести строку S1 c помощью оператора readln. Определить ее реальную длину. В строку S2...


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

Или воспользуйтесь поиском по форуму:
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