|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
||||||
Что быстрее конкатенация, формат или join строк?26.07.2016, 00:16. Показов 4438. Ответов 17
Метки нет (Все метки)
Доброго времени суток.
Будучи начинающим питоноводом озадачился вопросом скорости выполнения кода. Прочитав несколько статеек, несколько в непонятках нахожусь. Практически везде не рекомендуют сцеплять строки сложением, а использовать для этого функции или форматирование. Провел эксперимент в PyCharm 2016.1.4 и вот какие результаты получились для трех вариантов:
начало середина конец Elapsed time: 0.026 sec начало середина конец Elapsed time: 0.036 sec начало середина конец Как видно из результатов - лидером оказался join, чуток медленнее сложение, а вот форматный вывод серьезно отстает. И вот возник вопрос, это особенность версии PyCharm или общая тенденция?
0
|
||||||
| 26.07.2016, 00:16 | |
|
Ответы с готовыми решениями:
17
Что быстрее JOIN, IN или EXISTS Какой запрос правильнее и работает быстрее INNER JOIN или WHERE? Оптимизация кода, структуры базы, или что еще можно сделать что бы быстрее работало!? |
|
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
|
|
| 26.07.2016, 00:46 | |
|
В данном случае разница маленькая, но для длинных последовательностей сложение действительно мееедленное, и PyCharm здесь не при чём...
0
|
|
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 26.07.2016, 01:33 [ТС] | |
|
Я просто сейчас конвертер БД реализую, где подобных операций в цикле со строками ожидается за десятки миллионов. Объем конвертируемых данных очень приличный, так для меня выигрыш скорости в 50% на 3 операциях сцепления - уже очень впечатляющий результат.
0
|
|
|
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
|
||||||
| 26.07.2016, 07:20 | ||||||
|
Не правильно так проводить замеры производительности кода. Во 1 time не слишком подходит для этих целей, а во 2 сам цикл на пример тоже вносит "погрешность" измерения, потому что на его исполнение тоже нужно время.
Для замеров есть специальные библиотеки + профилировщики.
1
|
||||||
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 26.07.2016, 20:19 [ТС] | |
|
Возможно вы в чем-то правы, но ваш вариант тоже несколько оторван от реальности, не буду же я в реальном коде так писать. Как раз мой вариант с циклами, будет более близок к реальному коду. А вот результаты которые дает ваш вариант, несколько поменяли иные:
0.02749829302964452 0.058981702237210526 0.009178463550786164 Самым быстрым оказалось сложение, и самым медленным снова форматирование. Худшие результаты с форматным выводом в обоих случаях тоже неплохой аргумент отказаться по возможности, от такого способа работы со строками.
0
|
|
|
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
|
|
| 26.07.2016, 20:35 | |
|
Пытливый, в твоем приемере цикл используется не для вычислениий, а для того, чтобы получить цифры на которых нормально будет виден выйгрышь какого либо из методов. По этому все нормально, даже если тебе надо запрофилироовать код в котором есть цикл, кто тебе мешает поместить в функцию цикл?
0
|
|
|
Заблокирован
|
|
| 26.07.2016, 21:49 | |
|
Мб раскажешь подробней какую операцию тебе надо провести в конвертере?
0
|
|
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
||||||||||||||||||
| 26.07.2016, 23:31 [ТС] | ||||||||||||||||||
![]()
Каждое поле в таблице вот в такую обертку надо завернуть:
0
|
||||||||||||||||||
|
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
|
|||||||||||||||||||||
| 27.07.2016, 07:11 | |||||||||||||||||||||
0
|
|||||||||||||||||||||
|
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
|
||||||
| 27.07.2016, 14:03 | ||||||
0
|
||||||
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 27.07.2016, 19:33 [ТС] | |
|
Все это правильные советы, но я немного умолчал. У меня используется встроенный инерпретатор питона, версия которого мне неведома, в котором я много чего не могу использовать, например просто ввести символ ' c клавиатуры просто невозможно, только ". В нем нет поддержки и таких функций как "<{0}>{1}</{0}>\n".format или очень полезной конструкции with.
Насчет '\r', попробую. Спасибо
0
|
|
|
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
|
|
| 27.07.2016, 20:37 | |
|
Пытливый, это ты "хранимую процедуру" для postgresql пишешь? Или где это у тебя встроенный куда-то интерпретатор?
0
|
|
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 27.07.2016, 22:58 [ТС] | |
|
Да, встроенный в Легенду, если слышал про такого зверя
![]() Добавлено через 5 минут Вот за '\r' дополнительно спасибо, работает, а то меня самого напрягает код с chr(13).
0
|
|
|
21 / 21 / 2
Регистрация: 31.12.2015
Сообщений: 100
|
|
| 28.07.2016, 21:29 | |
|
Вообще пишут, что join быстрее.
0
|
|
|
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
|
|
| 29.07.2016, 14:55 | |
|
0
|
|
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 29.07.2016, 22:28 [ТС] | |
|
Сяп, не знал о такой штуке. Оказалась ver 2.4.2
0
|
|
|
2742 / 2341 / 620
Регистрация: 19.03.2012
Сообщений: 8,830
|
|
| 30.07.2016, 00:23 | |
|
Ууу, как все плохо....
0
|
|
|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
|
| 31.07.2016, 17:20 [ТС] | |
|
Ну не все так плохо
Я уже все почти сделал, сейчас причесываю, красоту навожу, оптимизирую и т.д.
0
|
|
| 31.07.2016, 17:20 | |
|
Помогаю со студенческими работами здесь
18
Сравнение строк или какой код быстрее работает ? Что быстрее: i++ или ++i ? Что быстрее 7 или XP? Что быстрее WHERE x=1 или WHERE x IN (1)?
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
|
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2.
Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
|
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
|
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
|
|
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2.
Данный документ берёт данные из другого нетипового документа. . .
|
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
|
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать программный контроль на предмет проведения документа. . .
|
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача:
1. Реализовать контроль заполнения реквизита. . .
|