|
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
|
||||||
Что быстрее конкатенация, формат или join строк?26.07.2016, 00:16. Показов 4399. Ответов 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)?
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
|
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога
Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip"
Извлеките архив и вы увидите. . .
|
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога
Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д.
Сборка примера
Скачайте. . .
|