|
5 / 8 / 4
Регистрация: 31.08.2013
Сообщений: 350
|
||||||
Обработка строк. Объясните действия готового кода11.08.2021, 18:05. Показов 2844. Ответов 24
Начал изучать Python.
Нашел решение одной задачи: "Сделать слова в обратном порядке не меняя своего положения. Кол-во пробелов остается"
0
|
||||||
| 11.08.2021, 18:05 | |
|
Ответы с готовыми решениями:
24
Объясните, пожалуйста, действия кода
Объясните смысл кода в 10 строк |
|
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
|
|
| 11.08.2021, 18:27 | |
|
1
|
|
|
|
|||||||||||||
| 11.08.2021, 19:00 | |||||||||||||
|
Открой документацию Python - там все описано. Открой книгу Лутца Изучаем Python - там все разжевано. Добавлено через 21 минуту
И, кстати, их не два, а три.
1
|
|||||||||||||
|
5 / 8 / 4
Регистрация: 31.08.2013
Сообщений: 350
|
||
| 12.08.2021, 22:39 [ТС] | ||
|
0
|
||
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
||||||
| 12.08.2021, 22:46 | ||||||
|
Worldmen,
1
|
||||||
|
5 / 8 / 4
Регистрация: 31.08.2013
Сообщений: 350
|
||
| 12.08.2021, 23:02 [ТС] | ||
|
0
|
||
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
|||||||
| 12.08.2021, 23:08 | |||||||
|
Вот почему бы не открыть доку и не посмотреть? Почему не поэкспериментировать? Все же становится ясно как Божий день.
0
|
|||||||
|
5 / 8 / 4
Регистрация: 31.08.2013
Сообщений: 350
|
|||||||
| 12.08.2021, 23:13 [ТС] | |||||||
Второй - for i in text.split(" ")
0
|
|||||||
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
||||||||||||||||
| 12.08.2021, 23:21 | ||||||||||||||||
|
Worldmen, в-общем ты ничего не понял из того, что я тебе написал. В методе join - один параметр. Это список.
s = " ".join([i[::-1] for i in text.split(" ")]) Да, это список. Я тебе разложил как это будет не в виде листкомпса, но ты не понял. Хотя и написал что понял. Добавлено через 1 минуту Вот это
Добавлено через 2 минуты
Теперь-то понятно?
2
|
||||||||||||||||
|
5 / 8 / 4
Регистрация: 31.08.2013
Сообщений: 350
|
|
| 28.08.2021, 22:55 [ТС] | |
|
очень хорошо объясняется синтаксис в обучении Pathon на stepik.org - Списочные выражения
0
|
|
|
|
|
| 28.08.2021, 23:08 | |
|
0
|
|
|
5 / 8 / 4
Регистрация: 31.08.2013
Сообщений: 350
|
||
| 28.08.2021, 23:29 [ТС] | ||
|
В первом 300 страниц рассказывается как :
Книги хорошие как help
0
|
||
| 30.08.2021, 11:20 | |||||||
Выражения в питоне помещаются в круглые скобки. А квадратные скобки, с размещенным внутри циклом for создают списковые включения. Именно такое у Вас. Для того, что бы понимать Ваш код, Вам нужно изучить синтаксис спискового включения. Хотя бы простой базовый синтаксис спискового включения. Но нужно иметь ввиду, что встречаются и списковые включения с довольно сложной, многоуровневой структурой, которые трудно читаемы. Такие коды в основном используют любители СИшного стиля программирования, где коды сжимаются по максимуму. ![]() А вообще то включения бывают разных типов, и различаются они применяемыми скобками.
0
|
|||||||
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
|
| 30.08.2021, 11:22 | |
|
0
|
|
| 30.08.2021, 11:35 | ||
0
|
||
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
||
| 30.08.2021, 11:39 | ||
|
Полностью согласен с Лутцем.
А вот эта ересь откуда? Viktorrus, вы сишный код вообще видели? Не helloworld ессно.
0
|
||
| 30.08.2021, 11:55 | |
|
"Общая оценка для всех заявлений о производительности в этой книге, касающихся списковых включений или других инструментов: относительная
скорость выполнения кода во многом зависит от конкретного тестируемого кода и используемой версии Python, а также предрасположена к изменениям от выпуска к выпуску. Например, в CPython 2.7 и 3.3 списковые включения по-прежнему могут быть в два раза быстрее соответствующих циклов for в одних тестах, но лишь минимально быстрее в других и возможно даже слегка медленнее в случае применения конструкций фильтров if." Лутц М. Изучаем Python (том 1, 5-е издание, 2019) стр. 452 "Не злоупотребляйте списковыми включениями: KISS. При такой универсальности списковые включения могут быстро стать малопонятными, особенно когда они вложенные. Некоторые задачи программирования сложны по своей природе, и мы не можем приукрашивать их в попытке сделать проще, чем они есть на самом деле (в качестве основного примера дождитесь грядущих перестановок). Инструменты вроде включений являются мощными решениями, когда используются разумно, и по существу нет ничего плохого в том, чтобы применять их в своих сценариях. Вместе с тем код, подобный представленному в предыдущем разделе, может выйти за границы допустимой сложности — и, откровенно говоря, способен непропорционально возбудить интерес у тех, кто придерживается ошибочного предположения о том, что запутывание кода каким-то образом намекает на наличие таланта. Поскольку такие инструменты имеют тенденцию быть притягательными для определенных людей больше, чем вероятно должны, я вынужден прояснить здесь область их применения. В книге демонстрируются усложненные включения в учебных целях, но в реальном мире использование неоправданно трудного для понимания и замысловатого кода служит признаком скверного проектирования и плохой заботы о его потребителях. Перефразируя мысль из первой главы: программа не должна быть заумной и непонятной — она должна четко сообщать о своем предназначении. Или вот один из девизов, выводимых import this: Простое лучше сложного. Написание кода со сложными включениями может быть веселым академическим развлечением, но ему не место в программах, которые когда-нибудь придется разбирать другим. Поэтому вот вам мой совет: в начале работы с Python применяйте простые циклы for и включения или вызовы тар в отдельных случаях, где их легко использовать. Как всегда, здесь применимо правило “сохраняйте его простым”: лаконичность кода — гораздо менее важная цель, чем его читабельность. Если вы вынуждены переводить код в операторы, чтобы понять его, то вероятно там и должны быть операторы. Таким образом, старый акроним KISS по-прежнему актуален: фраза Keep It Simple (сохраняйте его простым), за которой следует либо слово, считающееся в наши дни слишком сексистским (Sir (сэр)), либо чересчур красочным для такой книги, читаемой всей семьей… Обратная сторона: производительность, лаконичность, выразительность Тем не менее, применительно к данному случаю в настоящее время дополнительная сложность дает солидное преимущество в плане производительности: современные тесты в Python показывают, что вызовы тар могут выполняться вдвое быстрее эквивалентных циклов for, а списковые включения зачастую даже быстрее вызовов тар. Разница в скорости может варьироваться в зависимости от особенностей использования и версии Python, но в целом объясняется тем фактом, что тар и списковые включения выполняются со скоростью кода на языке С внутри интерпретатора, которая часто гораздо выше, чем скорость выполнения байт-кода циклов for внутри PVM. Вдобавок списковые включения обеспечивают лаконичность кода, которая поощряется и даже предписывается, когда из такого сокращения размера не вытекает также уменьшение смысла для следующего программиста. Кроме того, многие считают выразительность включений мощным союзником. Поскольку вызовы тар и списковые включения представляют собой выражения, синтаксически они также разрешены в местах, где операторы цикла for не допускаются, скажем, в теле функций lambda, внутри списковых и словарных литералов и т.п. По указанным причинам списковые включения и вызовы тар заслуживают изучения и применения для более простых видов итераций, особенно если скорость приложения является важным фактором. Однако из-за того, что циклы for делают логику более явной, они в целом рекомендуются на основании простоты и зачастую для получения более прямолинейного кода. В случае использования вы должны стараться сохранять вызовы тар и списковые включения простыми; для более сложных задач взамен применяйте полные операторы." Лутц М. Изучаем Python (том 1, 5-е издание, 2019) стр. 605-607 Так как объем текста посвященного разбору этого вопроса достаточно большой, я не стал давать его весь. Читайте указанные страницы.
0
|
|
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
|
| 30.08.2021, 12:03 | |
|
0
|
|
| 30.08.2021, 12:09 | |
|
Сорри, при копировании текста, map скопировалось как тар. Исправить уже не могу.
Добавлено через 3 минуты iSmokeJC, Просто я когда то немного изучал С++. И там часто группа команд заменяется одной командой. Что делает код очень компактным, но требует для его понимания высокого профессионализма (хорошего знания языка С++) Добавлено через 2 минуты И это ни как в питоне, когда одна команда обозначает одно укрупненное действие, а там одна команда может обозначать именно несколько действий, которые нужно помнить применяя эту команду.
0
|
|
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
|
| 30.08.2021, 12:13 | |
|
0
|
|
| 30.08.2021, 12:13 | |
|
Помогаю со студенческими работами здесь
20
В поисках готового кода Комментирование готового кода Комментирование готового кода Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git
main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели
8ATzM_2aurI
|
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2.
Задача: запретить редактирование документа, если он открыт у другого пользователя.
/ / . . .
|
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои.
А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
|
|
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
kYBz3eJf3jQ
|
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
|
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
|
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора
Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2.
Задача: уведомлять пользователя, если. . .
|