Я создал ввод, который позволяет мне составить список предложений (список), и ввод, включающий словарь с несколькими значениями (dict). Элементы списка и словаря различаются в зависимости от элементов, введенных пользователем.
Я пытаюсь заставить скрипт создавать список предложений из списка, случайным образом выбирая данные между {}
У вас есть решение с использованием random, itertool или re? Я полностью заблокирован.
Мои данные:
List = ["Je {suis|m'appelle} kevin rab et je suis {grand|petit} et {beau|moche}.", "Je {suis|m'appelle} sam slap et je suis {grand|petit} et {beau|moche}.", "Je {suis|m'appelle} bob clob et je suis {grand|petit} et {beau|moche}.", "Je {suis|m'appelle} lydie bal et je suis {grand|petit} et {beau|moche}."]
Dict = {"{suis|m'appelle}": ['suis', 'm%1apo%appelle'], '{grand|petit}': ['grand', 'petit'], '{beau|moche}': ['beau', 'moche']}
Я ищу такой результат (случайно):
['Je m%1apo%appelle kevin rab et je suis grand et moche.', 'Je suis sam slap et je suis grand et beau.', 'Je m%1apo%appelle bob clob et je suis petit et moche.', «Je suis lydie bal et je suis grand et moche».]
Привет, Карл. Спасибо за совет и за ссылку, действительно, я задал вопрос неправильно, и в следующий раз постараюсь сделать лучше (прочитав страницу о вопросах). Я недостаточно ясно выразился, к счастью, tobias_k нашел ответ на мой вопрос! Теперь я подробно расскажу об этом, чтобы лучше понять, как используется re.sub, конечно. Извините, если моя манера задать вопрос все равно пошла не так ^^
Вам не нужен dict
, вы можете просто использовать re.sub
с функцией обратного вызова, чтобы найти эти {...}
регионы и заменить их одной из альтернатив:
>>> text = "Je {suis|m'appelle} kevin rab et je suis {grand|petit} et {beau|moche}."
>>> re.sub(r"\{(.+?)\}", lambda m: random.choice(m.group(1).split("|")), text)
'Je suis kevin rab et je suis petit et moche.'
>>> re.sub(r"\{(.+?)\}", lambda m: random.choice(m.group(1).split("|")), text)
"Je m'appelle kevin rab et je suis petit et beau."
Соответствующая выдержка из документов:
If
repl
is a function, it is called for every non-overlapping occurrence ofpattern
. The function takes a single match object argument, and returns the replacement string.
Привет, Tobias_k, большое спасибо за объяснение! Я пытаюсь сделать это с 3 дней (я новичок), и я бы не подумал об использовании Lambda, потому что я еще не знаю, как его использовать. В любом случае, вы очень помогаете! Большое спасибо! Я постараюсь понять все в вашем коде, чтобы убедиться, что в следующий раз я смогу использовать re.sub и lambda =)
Никогда не используйте нужноlambda
. Это Только способ определить простые виды функций таким образом, чтобы они помещались в одну строку и не давали им имени (поэтому их также нельзя было использовать повторно). Здесь есть две важные идеи: во-первых, Python позволяет передавать функции (и методы) другим функциям (и методам) в качестве аргумента (да, сама функция, а не результата его вызова); и второе, что re.sub
принимает такой параметр и делает с ним что-то полезное (как объяснено в ссылке на документацию).
Добро пожаловать в Stack Overflow. Пожалуйста, прочтите Как спросить и попытайтесь подумать о проблеме, а затем разберитесь, где вы на самом деле застряли, чтобы задать конкретный вопрос. Это не служба написания кода. Начните с определения логических шагов к решению проблемы. Вы уже определили некоторые библиотеки, которые, как вы ожидаете, будут полезны, так что это говорит о том, что вы действительно имеете какое-то представление и на самом деле не «полностью заблокированы». Попробуйте подумать, почему вы решили упомянуть их, особенно
re
. Также попробуйте просмотреть документацию по соответствующим инструментам.