
Предыдущий: >>3327670 (OP)
Литература:
https://ln2.sync.com/dl/cf2c1d070#xq4s328t-xbbjys2z-9r6j7ss7-gf4e9dv6 <-- Книжки, новое собрание
Ещё книжки: https://yadi.sk/d/HQhhsBsq3TVRUq
Тоже книжки: https://yadi.sk/d/tArKKuQu3Kejuq
Анон, вместо того, чтобы без разметки постить код, лучше шарь его через специальные ресурсы:
https://online-python.com/ - листинги и онлайн-запуск
https://ideone.com/ - возможность постить листинги кода и онлайн-запуска, не требует регистрации
https://dumpz.org/ - можно постить листинги, не требует регистрации
https://pastebin.com/ - для листингов, регистрация не обязательна
https://goonlinetools.com/snapshot/share/ - для листингов, без регистрации, но с капчей
#######################################
Вопросы-ответы:
— С чего начать изучать питон?
У питона намного лучше официальная документация, чем у большинства других языков. Есть там и учебное пособие для начинающих: https://docs.python.org/3/tutorial/introduction.html , неофициальный перевод на русский язык: https://digitology.tech/docs/python_3/tutorial/introduction.html (для питона версии 3.8, но разницы почти нет)
https://github.com/yakimka/python_interview_questions - интересная подборка, масса разнообразных тем и вопросов, для продолжающих, всё на русском
— Какие книги считаются лучшими?
На слуху чаще всего Лутц, но там очень много воды. Ещё на слуху Марк Саммерфильд, Эл Свейгарт "Автоматизация рутинных задач с помощью python". Эти книги рекомендуют чаще всего, но книги довольно старые, а питон развивается.
— Есть у кого на примете годный курс лекций по алгоритмам? Формат лекций мне как-то ближе, нежели просто чтение книги.
МФТИшный курс, например, https://www.youtube.com/playlist?list=PLRDzFCPr95fK7tr47883DFUbm4GeOjjc0
— А как учить джангу? Нахожу книги по джанге 1.х, можно их использовать?
У джанги отличные доки (одни из лучших для пистоновских либ, имхо), почитай их для начала. Книгу по джанге можно читать даже для версий 1.x, т.к. принципы остаются теми же. Но лучше хотя бы с версии 2.0, слишком много мелких изменений в базе.
— Какие веб-фреймворки стоит учить в начале двадцатых?
Что бы не говорили, Джанго живее всех живых и умирать не собирается (и Django REST Framework), очень перспективный асинхронный FastAPI, асинхронный AioHTTP. Flask ещё где-то используется, но уже legacy. Прочие фреймворки или у нас экзотика, или это вымирающее легаси как Торнадо.
— В ньюфаг-треде написано, что нужно начинать с SICP, чтобы научиться программировать
Вот, пожалуйста, та же самая программа, но частично переработанная под язык Python: https://www.composingprograms.com/ (нужно знать ангельский или уметь пользоваться переводчиком)
— Что можно почитать/посмотреть по многопоточности/параллелизации в питоне, да и вообще в целом?
Ролик на американском языке про многопоточность и асинхронность, построение своего event loop с нуля, помогает понять, как устроена асинхронность внутри: https://www.youtube.com/watch?v=MCs5OvhV9S4
— Можно ли на питоне делать мобильные приложения?
Да, смотри на фреймворк Kivy https://en.wikipedia.org/wiki/Kivy_(framework) https://kivy.readthedocs.io но народ на него жалуется
— Как можно без лишней возни ускорить программу на питоне
1) проверь сначала свой код, алгоритмы и структуры данных. Чаще проблема здесь.
2) код можно иногда феерично ускорить, используя JIT (Just-in-Time) компиляцию. Почитай обязательно про модуль numba, он ставится через pip, и альтернативный интерпретатор PyPy.
— Дайте нормальные книжки на русском! Мы, блядь, не в пин##сии живём
Брат, смотри книжки по ссылкам в шапке, там есть и русские. Но помни, без языка ангелов твоя жизнь проходит мимо и ты обречён быть на обочине знаний и технологий.
ps: анон, если ты вносишь изменения в шапку, оставляй ссылку на код с обновлённым исходником.
текущая шапка: https://goonlinetools.com/snapshot/code/#z0o243n8t8byiy2zptv27
То что вам впаривают на курсах - это пиздеж.

>работы на питоне НЕТ. Питон это просто мелкий скриптовый язык, на котором пишется мелкая автоматизация
Подтверждаю.
Инфоцыгане с курсов создали 3к фейковых вакансий.
Ну на бэкенде удалёнке всего 250-300. А остальное там разрознено всё: AQA, DevOps/Sysadmin, Data Science/Data Engineer/DWH.
Ну давай разберем по частям тобою написанное.
1) Убираем нерелевантные слова - data, machine, machine, devops, преподаватель, куратор - чтобы отсеять девопсов, DS, ML и тех, кто ищет наставников для курсов
2) Убираем пункт "Искать в описании вакансии" - питон часто упоминается, как вспомогательный язык стека.
Остается уже не >3к, а всего 733 вакансии. По всем странам, далеко не все они удаленочные. Из них 472 вакансии требуют опыт от 3 лет, для джуномидлов подходят оставшиеся 261 вакансия.
Повторяем процедуру с резюме - 231 тысяча резюме, ищет работу примерно 14% (это можно вычислить по статистике открытых для обычных пользователей резюме), то есть 32 тысячи человек.
123 человека на вакансию.
А теперь проверни подобные операции с любым другим реальным языком промышленной разработки и сравни результаты.
Ищет работу 14к человек.
Количество вакансий с аналогичными фильтрами: 1180. 12 человек на место. Чувствуешь разницу?
Хуйню не неси. В джаве такой же уровень конкуренции. Если хочешь поменьше конкуренцию, то надо в девопс/1с/qa стартовать.
Я тебе сейчас с цифрами доказал, что уровень конкуренции в 9 раз ниже. В Джаве высокая конкуренция, но в отличие от питона есть вакансии и работа, а в петухоне тысячу вкатунов устраивают голодные игры за полторы вакансии.
>тысячи вкатунов
fix
>пишешь на питухоне, страдаешь от динамической лапши 24/7
>обмазываешься аннотациями, постепенно интегрируешь mypy, со временем mypy работает в strict режиме.
Сделал из вашего хуёвого и ебучего питона человека, ну и заодно затерпел и не стал перекатываться на сраное говно. Один лишь вопрос почему эта ваша ебучая нелюдь гвидо не сделает типы обязательными, а динамическую лапшу опциональной, то есть как сейчас, но наоборот?

В 22:00 прием лекарств, не забывай

class SomethingClass(ABC, dict)
В итоге получается так, что я могу создать экземпляр этого абстрактного класса.
Че делать?
Типа, даже если унаследуюсь, то могу вызывать абстрактные методы без их перегрузки. Жижа какая-то выходит.
Абстрактных методов в том виде, как в C++, в питоне нет. При желании ты это можешь реализовать играясь с метаклассами, но вот это нафиг никому не нужно
А вот против вызова таких методов есть стандартный паттерн, ты бросаешь исключение, специально для этого есть NotImplementedError
Ну разве что в джаве ситуация другая, с остальными так же можно всё вывернуть и получить копьё
Да хуйню чел запостил какую-то. Ну 200к резюме с упоминанием питона, какая часть из них вообще активная, а не многолетней давности?
Сейчас на хх есть счетчик откликов в мобильной версии, вот вижу на примере его джавы все те же триста шестьсот шестьсот двести двести откликов на первых рандомных вакансиях. Там еще стажерская свежая висит которую 50 человек смотрит. И кста я исключил из поиска андроид и qa на жабе, получилось столько же вакансий как у него на питон
12 человек на место, больше вакансий, каво нахуй наебать пытается челикью
Меньше всего конкуренция на шарпе, вакансий чуть меньше конечно, но не сильно меньше.

Но только, чтобы всё оффлайн работало, то есть обрабатывалось на моём компе и телефоне.
Я хоть в тот тред попал?
нет , 100% ему кто-то помогает . Мб просто озвучивает текст
Даже смотреть не буду. А ещё КЗОТ запрещает детей нанимать.
А остальные вопросы на ответ?
>разместил его на ВПСе
Фу, челядь ебучая. Нет смысла ради каких-то 1000 запросов в месяц арендовать сервер, он будет 0,00001% времени работать и 99,99999% времени простаивать. Бестолково и неэффективно, тупо переплата за простой.
Что тебе нужно автоматизировать, пидор?
>Бестолково и неэффективно, тупо переплата за простой.
Опять ты, клаудшиз.
Ну и что нынче подходит для телеграм-ботов?
У тебя просто нормальных друзей не было
Как найти классы-дубликаты?
Есть репозиторий с утилитой-кофигуратором.
В ней есть базовый класс BaseDevice и куча потомков вида DeviceFoobar22(BaseDevice), все конфиги хранятся в аттрибутах потомков.
Конфигов много, под 100 штук.
Хочу вывести список потомков-дубликатов, у которых фактически в ТЕКСТЕ КОДА написано одно и тоже, чтобы прописать им наследование от какого-то общего предка и сократить код. (Возможно это пиздец какая плохая идея и лучше не наследоваться вовсе)
Если собрать все классы, взять их аттрибуты (vars), то они будут уникальными, потому что аттрибуты инстанцируются по разным адресам памяти.
Есть какой-то лексический анализатор или другой способ искать избыточные классы-дубликаты?
>Cloudflare, очевидно же.
Бля, уверен что это окажется заманухой. Конторка в принципе гнилая. Лучше уж "VPS друга". Да и сложно это все

>Cloudflare, очевидно же.
Между прочим, что-то новое .
Ты перестал всем рассказывать какой охуенный AWS.
Ждем, когда окончательно образумишься.

"командная строка" - это программа cmd.exe
А ты запустил python.exe и пытается туда пихать команды, которые python не понимает.
мимо-добродвач
>Бля, уверен что это окажется заманухой. Конторка в принципе гнилая. Лучше уж "VPS друга"
Ну и сиди дальше, плати за 99,99999% простоя. Нет смысла тебя переубеждать.
>>378082
Я пользуюсь, меня всё устраивает. Зачем рассказывать если никакой полезной нагрузки в разговоре не будет. Мне влом тратить время на пустое бла-бла, если будет конкретный вопрос по конкретному сервису - то я отвечу.
>Ну и сиди дальше, плати за 99,99999% простоя
Около 0% простоя, поскольку телеграм-бот должен быть поднят всё время, даже если к нему никто не обращается
По логике долбоёба выше нужно отключать тг-бота на ночь, чтоб сэкономить 100 рублей.

400x400, 0:42
PyCharm довольно крут, спору нет, но дорого, а в комунити нет поддержки джанги и поддержка разных sql ограничена.
Может быть на VSCode перемещаться?
Для всего есть vi/vim/emacs. Если ты даже это не осилил, то не утруждай себя программированием.
неужели неочевидно что в этом баяне попугая сзади рукой двигают?
инбифо: накидал тебе за щеку, проверяй
Что такое "основная программа"? Фласк тоже вроде асинхронный. А аутентификацию как прикрутить?
Ты сайт делаешь, либо основной функционал твоей системы не в веб? То есть для чего тебе аутентификация?
На любом фреймворке можно сделать аутентификацию, под любой есть решения соответствующие. Но система же ещё что-то должна делать?
Смысл в том, что функционал интерфейса наверное не самый простой, на этом фоне авторизация лишь небольшая часть. Под это надо фреймворк подбирать. Ещё дальше вопрос в том, как у тебя бэкенд устройством управляет, у тебя синхронные инструменты или asyncio
Если у тебя asyncio-код, то aiohttp удобен, поскольку он построен так, что бы его можешь запускать как отдельный сервис твоей программы, причём можешь запускать, а можешь не запускать. Чаще фреймворки построены так, что всё должно плясать вокруг них, они центральную роль несут, что неудобно.
Короче подумай, какой фреймворк тебе симпатичен, и под него ищи авторизацию. Под любой есть что-нибудь.
Я почитал немного, вижу что в качестве "фронтендов" существуют
- Jupyter Notebook
- JupyterLab
- Какая-то ноутбучная пристройка к вскоду
Что из этого правильнее и/или удобнее юзать?
Спасибо за совет. Поищи, что-нибудь есть, но это не точно. А не проще будет джангу взять? Там оно точно есть и работает изкоробки.
jupyter notebook classic как будто брошенныйю Там серьезные беды с дебаггером. а у меня в wsl там вообще пизда сетевая какая-от.
Так что остается Jupyter Lab
Ну и Vscode, если ты и вправду погроммист.
>правильнее
Молниеносный детект студента или заводчанина.
В ИТ нет правил. Есть выгоды.
Тогда ты будешь постоянно мартышкин труд выполнять.
Ну а созвонами все равно заебут. Без никак вообще.
Я в такой. Небольшая контора, людей немного. Созвон раз в неделю.
Дают задачу и если сам можешь справиться, то можно вообще ни с кем не контактировать. Трекеров нет никаких. Можно работать в любое время, хоть ночью.
Минусы:
код невысокого качества, страдающий от динамики Питона
отсутствие документаций
нулевой онбоардинг
большое разнообразие задач: я и CI настраивал и systemd, и фронтенд, бэкэнд, нагрузочные тесты и ещё кучу всего
все проблемы твои личные по типу проект не можешь запустить, виртуалку настроить, контейнер поднять и т.п.
ЗП меньше 300кк наносек
Пиздец. Разве VSCode нуждается в каких-то советах?
Пиздец блядь, поставь себе нормальную ide. Я знаю только одну: pycharm
Рано или поздно тебе придется писать на других языках. И вот тут то тебе захочется единообразия.
Все норм иде от джетбрейн, на всех языках что мне надо было (жава/до диез/фитон).
>Ок, чем вс код лучше?
Шустрый, куча плагинов, ебически кастомизируется, бесплатно и без повесточки.
Во время работы играет путин-хуйло лала лала? Мне похуй на ваши русн епроблемы. Вскод шустрее пучарма?
Откуда ее вызывать, говно санкционное? Софт ему русофобский, фашисту ебаному.
l1=[1,2,3]
l2=['test1','test2','test3']
res = [x for y in zip(l2, l1) for x in y]
Конкретно - зачем нужна конструкция 'x for y in...'

850x372, 0:03
>Пучарм бесплатен
Только обрезок в видео комунити версии. Подойдет, если ты студент или самоучка, изучающий пиструн.
За нормальную версию у тебя попросят $199 за первый год (потом чуток дешевле).
Ну и чем Pycharm лучше VSCode, чтобы за него $200 отдавать? Просто ЧТО там такого, чего нет в VSCode и за что нужно платить ебаному кабану, чтобы он еще больше распух от денег? который к тому же еще и ренегат, а посему идёт нахуй

>Конкретно - зачем нужна конструкция 'x for y in...'
Это то же самое, что на моем пике, но формализованное в виде генератора, который быстрее, моднее и сахарнее.
А zip-объект, в который ты упаковал свои списки содержит примерно такое: ('test1', 1) ('test2', 2) ('test3', 3), то есть, берет из каждого итерирумого объекта по элементу от первого и до того момента, пока не кончится самый короткий из них. Все это упаковывает в набор кортежей.
Я тоже так делаю, когда нужно одновременно проитерироваться сразу по нескольким последовательностям.

Я сейчас читаю про Conda и кажется, что это оптимальный инструмент. Но при этом в проектах на глаза мне чаще попадались requirements.txt. Объясните как оно устроено в профессиональной разработке?
Типичный блядь питон. Есть pip, есть pipenv, есть конда, есть еще дохуя. Поди сука разберись какой из них хороший.
Проект с необходимостью точного воспроизведения окружения - использую reqs.txt и там все пакеты с == точными версиями .
>Чем тебя не устраивает комунити, по пунктам? Обрезок - это VS.
Зачем ты пытаешься в унылый "сам дурак"? Пукчарм камунити - это обрезок, обмылок, который хорошо подходит для чистого Питхона. Стандартная ситуация, когда ты студент или макака на курсах для начинающих. А речь идет именно о тебе.
Если ты реально работаешь, то тебе нужна поддержка баз данных, нужна поддержка фреймворков, вероятно нужна совместная работа. И ты соснешь делать это в своем обмылке.
Я пробовал разные IDE и редакторы, лучше, чем vim, pycharm и vscode - нет. Но vim для красноглазиков, pycharm - хороша только платная версия, в то время как vscode: умеет буквально всё, превосходит по функционалу pycharm, легковесный, с открытым кодом и с намного, намного более развитым сообществом во всех смыслах.
А почему не используется везде, например, Conda? Тем более раз уж она популярна у датасаентистов.
Я ее просто беру как пример, просто потому что она вроде бы все умеет, в том числе устанавливать и сам питон.
И опять же, вот у тебя на пике написано
>а) просто проект
>...
>б) с необходимостью того-то и того-то
Ну а если одновременно присутствуют разные проекты, разные менеджеры же будут конфликтовать между собой. Опять же получается лучше прицеиться к конкретному менеджеру.
Какой сам дурак? Я про мелкомягкую студию.
Я знаю джангистов которые на бесплатном пучарме работали.
> А речь идет именно о тебе.
Что со мной?
Какая еще совместная работа? Ты про VCS?
> vim,
Фубля красноглаз.
Пучарм тоже опенсорс.
Как давно этот vs code выстрелил?
requirements.txt + pip дают самое точное воспроизведение окружения
Собственно не понятно, что ещё надо. Проблема может быть в том, что невозможно создать окружение без конфликтов, когда один модуль хочет одну версию какого-то другого модуля, а другой другую версию этого же модуля.
Особенно стрёмно, когда пидорасы, что модули разрабатывают, тоже хотят точности и указывают зависимость как ==
Но это надо сказать не только питонячья проблема
>мне чаще попадались requirements.txt
Зависимости часто в setup.py запихивают, используют setuptools, но суть в целом та же, там тоже указывается диапазон версий для каждого модуля, как в requirements.txt
Вопрос в том, как разруливать зависимости, когда они конфликтуют, но тут история о том, что модули всё-таки добавляются не так часто, запихивание чего-либо по поводу и без повода в проект это дурная манера очень.
Если ты создаёшь модуль, по хорошему ты очень вдумчиво должен подойти к тому, какие версии в зависимости указывать, на практике даже в профессиональной разработке с этим проблемы бывают. Если ты указал некорректную зависимость, слишком точную, то никакой инструмент не позволит это исправить автоматом.
> Особенно стрёмно, когда пидорасы, что модули разрабатывают, тоже хотят точности и указывают зависимость как ==
Это какие, например?
> Собственно не понятно, что ещё надо. Проблема может быть в том, что невозможно создать окружение без конфликтов, когда один модуль хочет одну версию какого-то другого модуля, а другой другую версию этого же модуля.
Как обходить? Rpc?
>>383423
15-й стандарт. Есть еще pipenv.
dic = {'cat': '15', 'dog': '42', 'fish': '3', 'dog': '1', 'sun': '44', 'fish': '444'}
Его нужно привести к виду:
dic = {'cat': '15', 'dog': ['42', '1'], 'fish': ['3', '444'], 'sun': '44'}
То есть у меня в словаре повторяются ключи с разными значениями, нужно объединить значения по ключу. Как сделать?
если не работает через добавление переменных окружения то переустанови вскод с сбросом настроек и расширений
бля пока рефакторил result = {} проебал в начале бро
Массивы лучше использовать с числами, а если строки без вариантов, тогда лучше вот так:
old_animals = {'cat': '15', 'dog': '42,1', 'fish': '3,444', 'sun': '44'}
new_animals = {}
for key,val in animals:
_ new_ids = list(filter(lambda x: x in dict, val.split(',')))
_ new_animals[key] = ",".join(new_ids)
BoxLayout:
id: root
BoxLayout:
id: box
Button:
id: btn
Положим, я удалил box из root. Как сделать, чтобы btn узнал о том, что его теперь нет в отображении?
У меня подобное удаление в программе это постоянное событие, т.к. используются MDI окна и они скрываются/показываются (соответственно через remove_widget и add_widget). На момент, когда MDI окно скрыто, я хочу удалять mouse_pos события из Window, и когда наоборот окно показывается, хочу событие снова регистрировать. Можно конечно хуй забить, и так работает, но это некрасиво как-то чтоли. Из-за этого нагрузка при движении мышью в окне высокая, т.к. у меня много виджетов имеют бинды к Window.mouse_pos (всякие кнопки и прочая хуйня которая должна при наведении мыши подсвечиваться).

>помогите создать многозначный диктионарь
>ахаха! я вам говны невнятной накидал а вы решаете ухаха! пук
Чатжптун ты? Узнал тебя по шизойдным высерам.
Не знаю что такое киви, судя по всему какой то гуй, но при любом раскладе кнопка или любой другой элемент это объект в дереве, если ты к нему присобачил какие то методы то они вызываются когда он находится в дереве и в нем всплывают какие-то событя, которые ты обрабатываешь. Не совсем понятно что и кому ты собрался сообщать если объект в дереве отсутствует. Если он есть но скрытый/деактивный то обычно события их игнорируют, если в твоей киве или твоей реализации не игнорируют, то ставь проверку аттрибута hidden и возвращай, либо отцепляй события на время скрытия.
Во-первых, как уже сказал анон выше, как в словаре могут поаторяться ключи?
Во-вторых, у вас в питоне что, в стадлибе нету group_by? Серьезно блять?
Для кого ideone придумали?
Если погуглить, может и найтись.
Пучарм может даже может сам создавать венв и ставить модули из requirmeents.tzt
> Если ты реально работаешь, то
> нужна поддержка баз данных
Не нужна. Встроенные эдиторы бд везде говно. 99% знакомых разрабов сидят на бобре, оставшийся 1% анальных рабов жидбрейнс на датагрипе
> нужна поддержка фреймворко
Только и исключительно если ты пишешь на штанге
> нужна совместная работа
Не нужна
При этом ты не написал про remote execution и дебаггер в докере. Ну, охуительно работаешь, братан
> vscode
> умеет буквально всё
Ага, и 90% из этого "всего" сделано через жопу, чем невозможно пользоваться. Про говнодебаггер и обосранный гит я промолчу, это просто ебаный позор
> превосходит по функционалу pycharm
Удивительные истории,
> легковесный
Легковесный только до той поры, пока ты не поставил 40-50 экстеншенов, чтобы нормально работать.
> с открытым кодом и с намного, намного более развитым сообществом во всех смыслах
Да, это же очень важно. Каждый разработчик после рабочего дня собирается контрибьютить в иде, которой пользуется.
Интересно, а почему ты не написал, что VSCode это говнина на электроне с инпутлагом, а пукчарм это нативное приложение?
Активируй венв. Пиздос, ну какие-то базовые концепции работы с консолью же нужно знать
Почему на питухоне нельзя разрабатывать тырпрайз с таким же успехом как на джава-говне-сисярпе?
на винде иначе не бывает. на линуксе заебись
Пчелидзе, на питоне яндекс такси, самокат и авито сделаны. Нахуя ты фантазируешь?
Так твой код не работает, он не сохранит нужный кабану список значений. Можешь проверить.
Короче реально херня вышла - в словаре не может быть одинаковых ключей (я не тестил просто).
В общем, подмогните с такой ситуевиной:
Есть несколько листов вида
x = [cat, 12, sun, 1, fish, 5, cow, 13]
y = [dog, 121, flower, 1, fish, 5, cow, 100]
В этих листах некоторые элементы совпадают. Необходимо все это дело запихнуть в один лист формата:
z = [cat, 12, dog, 121, flower, 1, sun, 1, fish, 5, 5, cow, 13, 100]
Словарь - лучший вариант, но проблема в том, что если из листов сделать словари, потом их замержить, то значение у ключа будет только одно. Например, из вышеуказанного словарь (после мержа) получится примерно такой:
dic = {cat: 12, dog: 121, flower: 1, sun: 1, fish: 5, cow: 100}
А необходимо такой:
dic = {cat: 12, dog: 121, flower: 1, sun: 1, fish: [5, 5], cow: [13, 100]}
Другая проблема в том, что у меня листы генерятся в цикле. Я могу аппендом добавлять данные в новый лист, но как потом его причесать под нужный мне вид {ключ: [значение, значение, значение]}?
У меня такое даже в неовиме работает на pyright это как раз от вскода лангуаге сервер
Я не знаю правильно ли я тебя понял, но сделай примерно вот так:
x = ['cat', '12', 'sun', '1', 'fish', '5', 'cow', '13']
y = ['dog', '121', 'flower', '1', 'fish', '6', 'cow', '100']
merged_list = [x, y]
res_dict = {}
for i in range(0, len(merged_list), 2):
key = merged_list
val = merged_list[i+1]
ext_val = res_dict.setdefault(key, val)
if isinstance(ext_val, list):
ext_val.append(val)
elif ext_val != val:
res_dict[key] = [ext_val, val]
print(res_dict) # {'cat': '12', 'sun': '1', 'fish': ['5', '6'], 'cow': ['13', '100'], 'dog': '121', 'flower': '1'}
https://github.com/microsoft/pyright/blob/main/docs/settings.md
python.analysis.autoImportCompletions [boolean]: Determines whether pyright offers auto-import completions.
Можно мышкой в настройках найти. Или в жсоне CTRL+P Open User Settings (JSON) туда пишешь "python.analysis.autoImportCompletions": true
Нахуя тебе это надо? Ты явно пытаешься решить какую-то другую проблему, так что ее и неси, а не эту хуйню со списками
В общем, есть python скрипт, который циклично выполняет свою задачу. Запускаю его через bat-файл, содержимое которого title (например script) и команда запуска, всё.
В термина выводятся просто принты о ходе выполнения. Скрипт никакого инпута не требует, живёт сам по себе.
Всё работает нормально, но в какой-нибудь рандомный момент скрипт может зависнуть, а заголовок батника меняется на "Выбор script".
И вот я не пойму, что это такое и из-за чего это может возникнуть?
Проблема особо не гуглится.
Может ли быть такое что в PyCharm параллельно висит "проект" этого скрипта и в момент дебага он запускает одноименный (title такой же как и название проекта) процесс, из-за чего основной скрипт виснет? Однако иногда я дебажу параллельно и норм всё.
Google: ideone
Какие ватники, о чём ты? Поставь операционную систему вместо виндуса, должно помочь. Если вдруг нет - в питухоне вроде есть нормальный дебаггер из коробки, расставь брейкпоинты и смотри, чё там лежит в переменных. В виндувсе через ватники и даблклики юзер-инпут ты вряд ли нормально пробросишь (да и печатать что-то в цмд.екзе один хуй мерзко), поэтому операционную систему в любом случае придётся установить.
Это по работе, поэтому систему поменять не вариант.
Сам скрипт работает нормально, и даже в батнике.
Просто в рандомный момент спустя 3 часа или 15 минут меняется заголовок батника на "Выбор..." и всё.
>поэтому систему поменять не вариант.
Ну тогда энжой ё виндус, что тут сказать. Да, виндус - это всегда боль, как только ты пытаешься делать что-то сложнее потреблядства, на которое он и рассчитан - поди отгадай, что у него на этот раз отъебнуло.
Прыщедолбоеб, питон на винде почти нормально работает. Иди нахуй, то есть на прыщи!
>почти нормально работает
Спермодаун, питон на винде это чужеродный портированный с прыщей софт, некрософт его из коробки не поддерживает, нигде ни в каком виде установить не предлагает, зато предлагает дотнет и бобрпшел и прочее свое говно, которое специально создавалось под шинду.
Так что давай проебись отсюда.
Посмотри все места где скрипт заголовок меняет
То есть для тебя скачать инсталлятор это мозговая перегрузка? -15 мозолей штульмана.
Зачем prev? Почему нельзя пройти от первого до предпоследнего и сравнить элемент с последующим?
потому что я нубик и пока не применяю никакие алгоритмы
list это функция стандартной библиотеки
Используй что нибудь типа list_of_nums
Числа лучше сравнивать с числами, и инициализировать переменную как:
prev = -1
либо минимальным числом
Ну и непонятно что тебе дает выявление дубликатов, убирать их из массива это пиздец как неэффективно, надо создать новый отсортированный отфильтрованный массив и все.
тогда незаморачивайся, пиши как понимаешь
> есть python скрипт, который циклично выполняет свою задачу. Запускаю его через bat-файл
Нахуя? В винде есть планировщик заданий. Запускай через него.
Почему у тебя отсутствует подсветка синтаксиса? Используй нормальную иде типа пукчарма. И не используй названия из билтинов питона

> в 2025г не иметь страницы вконтакте)))
Я с гейоси на линух в свое время ушел из за того что эта ос из линукса с человеческим лицом превращена в окукленную версию ios для десктопа. Линукс наоборот из саморазваливающейся хуйни превратился в нормальную операционную систему, с красивыми и функциональными UI. с понятно работающей и единой системой ярлычков и меню (XGD), с контейнерными приложениями .appimage, с протоном который все стимовские (и не только) игры запускает без проблем практически. есть системд демоны (аналог макосных лаунчд) есть фаирвол (которым можно наебать dpi провайдера) есть вайфай-блютус-4g нетворкинг через встроенный нетворкменеджер, есть запоминание сортировки размера расположения каталогов без всяких .DS_Store как в макоси, темные темы на любой вкус и апскейлинг.
Остались конечно и проблемы, но это мелочи по сравнению с тем что пидор очкастый предлагает своим пользователям. Про Windoшс Retard Edition даже вспоминать тошно
Мне впадлу спорить, единственное реальное преимущество линупса сегодня -- это нативный докер. Раньше в принципедокер был только под линукс по сути и сидеть на чем-то кроме него было безумием. Так что я пару лет был вынужден работать с него. Сейчас можно переехать спокойно на wsl с docker desktop'ами и жить не тужить
Хуже, сорт оф датасатанист с облачными вычислениями
Если так, то в чем? Пыха тоже интерпретируемая, но быстрее питона.
> после отключения гила?
Какого отключения? Ты о чем вообще? Фритрединг это эксперементальная фича, которая непонятно когда готова будет
> Почему питон не стал значимо быстрее во всех сценариях
А в каких сценариях, кроме мультитрединга, он даже в теории мог стать быстрее? Ты вообще понимаешь что такое гил?
> Получается, проблема была не в нем?
Про какую нахуй проблему ты говоришь. Разберись сначала что такое гил, а потом вопросы задавай
Если мне нужно передать в метод класса аргумент таким образом как это на втором примере, то как заставить это работать, чтобы явно не писать например d4.roll(4), блядь, ибо смысл класса теряется, хули я могу тогда процедурно писать вообще. Кубики как пример ессесно.
> мне нужно передать в метод класса аргумент
> но не передавать аргумент
Чего блять? Вопрос сформулируй нормально.
И в питоне переменные camelCase'ом не пишут, используют snake_case
numberOfSides => number_of_sides
А вот имена классов уже UpperCamelCase
die => Die
Я бухой, братик. Ща постараюсь.
Условно у нас есть класс:
class Class:
....def __init__(self, some_arg):
........self.some_arg = some_arg
....def my_method(self, some_arg):
........do_something(some_arg)
Создаём его инстанас:
a = Class(x)
При попытке вызвать a.my_method() получаем ошибку того, что нет требуемого позиционного аргумента. Получается инстанс класса не передаёт в метод some_arg, если указать аргумент явно a.my_method(x) то всё работает верно.
Так же вроде бы корректно работает конструкция вида:
....def my_method(self):
........do_something(self.some_arg)
Но вот как реализовать одновременно работу по аргументу, который мы передаём классу инстансу при создании, с возможностью сохранения явной передачи аргумента при вызове метода? Через попытку передавать в аргументы метода self.some_arg или через дополнительную переменную - вылезают ошибки.
И да я ковыряю питон и доки аж 5 час, мне просто нужно написать небольшой (строк на 4000) скриптик на питоне. И желания слушать "обучающий" гундёж на ютубе нет. По этому бест практикс, правильное форматирование кода и нюансы языка мне не ведомы, как-то так.
Так в чём проблема написать так:
....def my_method(self, some_arg = None):
........if some_arg if None:
............some_arg = self.some_arg
........do_something(some_arg)
> Ногил в 13
Какой ногил, это тестовая фича, которая параметром в билде устанавливается
> Во всех.
Значит ты еблан, который не знает что такое гил. Ты бы хоть минимально изучил вопрос, прежде, чем пукать что-то
> Про медленность питона епт.
В скольких компаниях был -- везде переезжали на питон для повышения производительности. А секрет очень прост -- внутри практически всех либ живет чистый си, который ебет даже плюсы по скорости, при этом позволяя разрабатывать раз в 10 быстрее, чем в случае чистого си
>>388332
Тебе уже написали вот тут как можно это решить >>388357
Правда можно написать даже короче, но тут скорее на вкус и цвет
....def my_method(self, some_arg = None):
........some_args = some_args or self.some_args
........do_something(some_arg)
Но ты уверен, что тебе это реально надо? Выглядит как хуйня ради хуйни плюс возможная протечка абстракции
>Какой ногил, это тестовая фича, которая параметром в билде устанавливается
Ну так изучи вопрос, прежде чем базарить. Почему питон не стал значимо быстрее во всех сценариях после отключения гила?
>Значит ты еблан, который не знает что такое гил. Ты бы хоть минимально изучил вопрос, прежде, чем пукать что-то
>Получается, проблема была не в нем? [не в гиле]
>В скольких компаниях был -- везде переезжали на питон для повышения производительности. А секрет очень прост -- внутри практически всех либ живет чистый си, который ебет даже плюсы по скорости, при этом позволяя разрабатывать раз в 10 быстрее, чем в случае чистого си
Заржал.
> Почему питон не стал значимо быстрее во всех сценариях после отключения гила?
Почему после релиза нового чатжпт не упали цены на квартиры в Москве?
Ну т.е. ты не знаешь. Иди книжки почитай какие-нибудь, того же Лутца можешь навернуть для начала.
Ну т.е. ты не знаешь. Иди книжки почитай какие-нибудь, того же Роджаса можешь навернуть для начала.
Для инклюзивности
Почему во многих проектах, таких как Джанго, стали переименовывать ветки из master в main после того, как сдох нигер уголовник и наркоман? До этого 20 лет всем похеру было.
Потому что примерно такого же цвета будут угли, которые останутся от сгоревшей жопы, после использования этого говна
ruff, как существительное, относится к жестко накрахмаленному оборчатому или плиссированному круглому воротнику из ткани, который носили в XVI и XVII веках
Скорее всего что-то типа rust-written fast formatter.
Перестала работать, пишет, что отсутствует несуществующий файл (поиском проходил), что может быть?
Питон обновлял, в архиве программы нету такого файла (infotor_2.py).
Софт: вьювер оффлайн-версии сайтов в sql формате.
https://drive.google.com/file/d/19E8UflBmd8OdGYvWytrX44MpE4DEH7HF/
Всё, разобрался, нужно было переустановить Python и подключить legacy-cgi. Я как понимаю веб-сервер не эмулировался, от этого и ошибки.
Чел... у меня пивной животик, я хочу себе отчётливые шесть кубиков на животе, скажи за сколько я смогу их получить ходя в спортзал? Мне надо шоп прям вырисовывались и тёлки текли. Вот скажи, за какое время они появятся? При том, что у меня была пятёрка по физкультуре и я катался на велике.
6 месяцев
А тебе не по хуй? Написано в доках не лезь, значит не лезь
В питоне ооп как в джаваскрипте, без приватных полей и методов, используй черточки:
self._param1
self._myMethod1()
Сделано так потому что семантическое разделение проще как в реализации так и для программиста более выразительнее на самом деле, ибо позволяет без IDE от жидбреинс видеть что приватное а что нет.
Питон вроде как хотел быть легким простым, но даже несмотря на то что он разжирел тенденции таковы что вместо public private static protected abstract interface будет:
(async) function method(self_object, args...) //public
(async) function name(args...) // static
Бредик не пишем. До приватных полей можно достучаться в любом языке с рефлексией(а это литералли все языки хоть сколько нибудь популярные). Так что если ты немного подумаешь, то задашь вопрос
> Зачем во всех языках так сделано, что до приватных методов все равно можно достучаться?
И ответ такой -- приват/паблик/протект методы это просто пометка для разработчика, не более. Есть одно функциональное назначение у приватных методов -- не допустить случайного переопределения метода в наследнике(допустим у тебя 50 уровней наследования и какой-нибудь метод self.update, который ты написал в своей реализации, может определяться каким-то из классов наследников и ты все сломаешь). Для такого в питоне есть name mangling с двумя нижними подчеркиваниями
Говно, ебало захлопни и сиди тихонько. Ты даже смог осознать о чем я написал. Пиздец, какой наглый вкатун, услышал краем уха какую-то рыготину, извалялся в ней и пришел в питонтред ей размахивать. Попустись
Говно, я же тебя сказал -- ты не понимаешь о чем вообще говоришь. 5 минут в гугле
https://github.com/jwalton/babel-plugin-private-class-fields-to-public
Но я не удивлен, как бы классические 3 пункта, по которым легко поймать за руку долбаеба:
1. Получить доступ к приватным полям нельзя
2. Ну, если уж и можно получить доступ к приватным полям, то чем больше действий нужно предпринять разработчику для получения доступа к приватным полям, тем безопаснее что бы это нахуй не значило код
3. Если ограничение доступов никак с безопасностью, то уж наличие private полей и сложность доступа к ним извне это и есть инкапсуляция
>babel-plugin-private-class-fields-to-public
>There's this TC39 proposal to add private properties to javascript classes, which are "hard private" - you can't access them from other scopes.
Вот же даун, пиздец
В джаваскрипте нет приватных полей, а если бы были как в джаве и пхп ты не можешь к ним обращаться чисто семантически, их нет в публичной области видимости, в этом их смысл.
> В джаваскрипте нет приватных полей
Это троллинг тупостью?
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes/Private_properties#syntax
> если бы были как в джаве и пхп ты не можешь к ним обращаться чисто семантически
В джаве и пхп точно так же обращаться можно
> их нет в публичной области видимости, в этом их смысл.
Нету, а обращаться можно. Как так?
>>390478
Нет, а ты?
Это недо-приват через спецсимвол (решетку)
Чтобы компилятор просто бил по рукам когда вне метода объекта пытаются обращаться к таким полям.
> В джаве и пхп точно так же обращаться можно
Как "точно так же"?
> Это недо-приват через спецсимвол (решетку)
А "недо" потому что тебе не нравится?
> Чтобы компилятор
Ты даже не представляешь насколько глубока кроличья нора в жсе, зачем ты споришь?
> Как "точно так же"?
Точно так же через рефлексию и интроспекцию

Пиздец
Как быть? pyinstaller не захотел переваривать мой скрипт, но подозреваю, что с ним будет подобное, если заставлю

Один раз?
Все-таки осилил фризинг с pyinstaller (эта хуйня не любит мультипроцессинг и нужно вот так в импорте добавлять оный from multiprocessing import Pool, freeze_support )
Стало лучше, теперь вирустотал выдает 5/72
ААА! Вирус! Не кочайти там вирус. Вот смотрите на вирус тотал БолгеносСканерПро показывает что там вирус ТороянНагибатор666
Что ты там продавать собрался, шиз? И зачем для этого тебе exe'шник? Не проще создать какой-нибудь инсталлер для винды или хотя бы батник?
Допустим, есть функция пик1, которая делает действие, но с двумя условиями. Код каждого условия не слишком большой, но уже достаточен, чтобы сделать рефакторинг.
Я могу пойти двумя путями:
1. Под код каждого условия создать две отдельные функции и вынести их в модуль на тот же уровень, что и управляющая функция. Пик 2. Причем тут я добавил нижнее подчеркивание в начало имени новых функций, чтобы показать, что они является "внутренними" и не предназначены для внешнего использования.
2. Сделать почти то же самое, что в предыдущем пункте, но разместить функции внутри самой управляющей функции. Пик 3
Попрошу не обоссывать меня, возможно с очень нубскими вопросами.
Забыл добавить, что в первом варианте меня смущает именно то, что само модуль будет "засорен" разного рода мелкими функциями. А при третьем варианте создается иллюзия кого-то порядка что ли.
Как делать принято обычно и как вы делаете чаще всего?
>пик1, которая делает действие, но с двумя условиями. Код каждого условия не слишком большой, но уже достаточен, чтобы сделать рефакторинг
Я не вижу для этого причины.
>Я не вижу для этого причины.
На самом деле причина есть, код в каждом условии уже довольно объемный и необходимость выделить уже сама навязывается.
Бро, вопрос тут не стоит делать рефакторинг или нет, для этого слишком мало данных. Вопрос стоит в том, как делать рефакторинг правильно из двух предложенных вариантов, ну или пусть с каким-то третьим вариантом.
В моём понимании не существует "правильного рефакторинга". Всё зависит от окружения.
Если у тебя там всего < 500 строк, то фигачь, что угодно вообще.
А если много кода, то зависит от окружающего кода.
Глядя на 3 картинки, я вижу самое понятное на первой.
>А если много кода, то зависит от окружающего кода.
Можешь предположить варианты? Первая часть понятна, что если кода мало, то можно делать как угодно, а если его много какие есть варианты?
Ну закинь код куда-нибудь на гитхаб. Проведём код ревью всем тредом.
Я не знаю, что можно сказать по обрывкам пары функций.
пик 1 делай максимально дотошно буквально чтобы как книгу можно было читать и выноси даже строчки, если оно тому надо
пик 2 можно еще сделать в виде классов общие по схожести функции чтобы еще больше ориентироваться в коде
пик 3 можно укоротить if и сделать строчки вряд тип если не оч напряжно будет выглядеть
пик 4 можно еще сделать возвращаемые типы и документацию к клоассам
такими шагами и работаем это база
Тебе надо сделать две функции вместо одной. У тебя принципиальная ошибка в том, что у тебя в принципе такая функция появилась. Если у тебя в зависимости от параметра функция начинает принципиально разно выполняться, то это две разные функции

440x480, 0:27
>пик 1 делай максимально дотошно буквально чтобы как книгу можно было читать и выноси даже строчки, если оно тому надо
Можешь пожалуйста развернуть мысль по этому примеру? Для меня это выглядит как пиздецовый огород, но судя по всему ты шаришь в этой теме, хотелось бы получить наставления.
Я сам чмо немного, этот тоже прав >>393304
Вот задачу берем простую тип например вывести самое большое число, не кратное 3
На вход похуй какой массив
Описываем словами сначала шаги
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задаче
Сортируем массив по убыванию
По каждому элементу проходим, пока не найдем не кратное трем
Результат равно найденному числу
Вернуть результат
"""
Почти каждое предложение/ шаг - функция. Показываем что принимает и чему присваивается ее результат (создаем - переменные, поэтому не считается за функцию)
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задач
Сортированный массив = Сортируем массив по убыванию(массив)
Первое число не кратное трем = По каждому элементу проходим, пока не найдем не кратное трем(сортированный массив)
Результат равно найденному числу
Вернуть результат
"""
Переводим в английский, сокращая название чтобы не было тотальный пиздец в 40 символов + обьявлем переменные
"""
result = -1
sorted_massive(array) = sorting_array(array)
first_not_for_three = find_first_not_for_free(sorted_massive)
result = first_not_for_free
return result
"""
В итоге у нас появилось тело алгоритма рабочего, но нужно сделать еще 2 функции низшего уровня
sorting_array(array) и find_first_not_for_free(sorted_massive)
Там также описываешь что она должна делать
sorting_array(array) тут в питоне можно сразу sorted() или .sort() юзануть ТК язык позволяет, в других языках надо алгоритм подробнее описывать тк там нет такого и руками надо сортировать
В find_first...(Sorted_massive)
Берем элемент
Если он не кратен 3 то return элемент
Как-то так извиняюсь за говнокодьместами
Я сам чмо немного, этот тоже прав >>393304
Вот задачу берем простую тип например вывести самое большое число, не кратное 3
На вход похуй какой массив
Описываем словами сначала шаги
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задаче
Сортируем массив по убыванию
По каждому элементу проходим, пока не найдем не кратное трем
Результат равно найденному числу
Вернуть результат
"""
Почти каждое предложение/ шаг - функция. Показываем что принимает и чему присваивается ее результат (создаем - переменные, поэтому не считается за функцию)
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задач
Сортированный массив = Сортируем массив по убыванию(массив)
Первое число не кратное трем = По каждому элементу проходим, пока не найдем не кратное трем(сортированный массив)
Результат равно найденному числу
Вернуть результат
"""
Переводим в английский, сокращая название чтобы не было тотальный пиздец в 40 символов + обьявлем переменные
"""
result = -1
sorted_massive(array) = sorting_array(array)
first_not_for_three = find_first_not_for_free(sorted_massive)
result = first_not_for_free
return result
"""
В итоге у нас появилось тело алгоритма рабочего, но нужно сделать еще 2 функции низшего уровня
sorting_array(array) и find_first_not_for_free(sorted_massive)
Там также описываешь что она должна делать
sorting_array(array) тут в питоне можно сразу sorted() или .sort() юзануть ТК язык позволяет, в других языках надо алгоритм подробнее описывать тк там нет такого и руками надо сортировать
В find_first...(Sorted_massive)
Берем элемент
Если он не кратен 3 то return элемент
Как-то так извиняюсь за говнокодьместами
А ну и главное помни, что функции, которые ты делаешь в ходе алгоса своего (низшие функции) стоят сверху по коду, поэтому как огород может выглядеть и то не идеально
Не занимайся хуйней. Если у тебя функция в зависимости от параметра принципиально меняет свое поведение, то это хуйня. Этим просто невозможно пользоваться. По своему опыту гигасеньора рассказываю как будет через 10-20 часов разработки:
1. Окажется, что для апдейта нужно передать ещё 4 отдельных аргумента в конструктор, а для серча 6 аргументов, чтобы сделать фильтры. По итогу, у тебя будет монструозная функция с 15 аргументами, причем при вызове функции нужно передавать разный набор аргументов в зависимости от action. Эта хуйня постоянно будет падать, так как где-то не передал одно, где-то не передал другое. Где-то не поставил значение по умолчанию и половина функций отвалилась, а вторая половина отработала.
2. При апдейте возникает исключение, если поля конфликтуют друг с другом, а при некорректных фильтрах возникает уже свое отдельное исключение. По итогу, на каждый пук ты будешь писать 30 строк try except. Где-то вызвал функцию и забыл поймать какое-то исключение, где-то поймал слишком общее исключение и не смог нормально обработать его
3. Апдейт стал возвращать объект питона, а серч массив строк. По итогу, при каждом вызове тебе нужно проверять тип данных, которые тебе вернулись. Постоянно все отваливается, то у тебя приезжает массив туда, где ждали просто объект, то получаешь объект, когда ждали массив. И это ещё простая структура, если не повезет, то будет вложенный словарь словарей, где одна только валидация типа, который вернулся, будет занимать 100 строк.
Так что я повторюсь — не занимайся хуйней
Этого двачую
Обычная функция? У тебя как минимум 5 разных интерфейсов вызывается. Ты удивишься, но в эту "обычную функцию" с названием sum_array я могу запихнуть словарь, а на выходе получить массив словарей. Конечно, это нихуя не простая задача jit это скомпилить
ну я там дальше компилю с четким указанием типов np.int64 - один вариант.
Тут прикол в том, что юзаются все возможные регистры в современных процессорах (xmm,ymm) и это еще долхый устаревший ноутбук
Чел, если что, там изначально можно просто сделать sum(a) и не писать никакую функцию. Тут речь именно про numba и ее внутренние оптимизации, которые видимо довольно хуевые(я не особо шарю), но возможно дело в том, что чел использовал тип данных из нампая, а не из ctypes, но я не настолько хорошо знаком с исходниками спитона
Это охуительно оптимизированный код, долбоеб
>gradual typing
Слабоват
1) дженериковых типов нету в рантайме
2) майпай не очень может в паттерн матч
Чё там планируют как-то в эту сторону двигать язык?
Мне так нравится.
Это промежуточные исследования для куска другого проекта.
Наконец-то я придумал пет-проект в котором это все действительно будет важно.

Мне нужно слепить свою бд в postgresql к джанго проекту.
проверил работу проекта. Сервер запускается. Но при смене бд (с sqlite по умолчанию) консоль ругается и высирается мне на голову ошибки. Что может быть?
Ошибки
Traceback (most recent call last):
File "A:\all_for_project\.venv\myshop\manage.py", line 22, in <module>
main()
~~~~^^
File "A:\all_for_project\.venv\myshop\manage.py", line 18, in main
execute_from_command_line(sys.argv)
~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\__init__.py", line 442, in execute_from_command_line
utility.execute()
~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\__init__.py", line 436, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\base.py", line 413, in run_from_argv
self.execute(args, cmd_options)
~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\base.py", line 459, in execute
output = self.handle(args, options)
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\base.py", line 107, in wrapper
res = handle_func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\commands\migrate.py", line 118, in handle
executor = MigrationExecutor(connection, self.migration_progress_callback)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\executor.py", line 18, in __init__
self.loader = MigrationLoader(self.connection)
~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\loader.py", line 58, in __init__
self.build_graph()
~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\loader.py", line 235, in build_graph
self.applied_migrations = recorder.applied_migrations()
~~~~~~~~~~~~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\recorder.py", line 89, in applied_migrations
if self.has_table():
~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\recorder.py", line 63, in has_table
with self.connection.cursor() as cursor:
~~~~~~~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 320, in cursor
return self._cursor()
~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 296, in _cursor
self.ensure_connection()
~~~~~~~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 279, in ensure_connection
self.connect()
~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 256, in connect
self.connection = self.get_new_connection(conn_params)
~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\postgresql\base.py", line 332, in get_new_connection
connection = self.Database.connect(conn_params)
File "A:\all_for_project\.venv\Lib\site-packages\psycopg2\__init__.py", line 135, in connect
conn = _connect(dsn, connection_factory=connection_factory, *kwasync)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc2 in position 61: invalid continuation byte
Мне нужно слепить свою бд в postgresql к джанго проекту.
проверил работу проекта. Сервер запускается. Но при смене бд (с sqlite по умолчанию) консоль ругается и высирается мне на голову ошибки. Что может быть?
Ошибки
Traceback (most recent call last):
File "A:\all_for_project\.venv\myshop\manage.py", line 22, in <module>
main()
~~~~^^
File "A:\all_for_project\.venv\myshop\manage.py", line 18, in main
execute_from_command_line(sys.argv)
~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\__init__.py", line 442, in execute_from_command_line
utility.execute()
~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\__init__.py", line 436, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\base.py", line 413, in run_from_argv
self.execute(args, cmd_options)
~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\base.py", line 459, in execute
output = self.handle(args, options)
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\base.py", line 107, in wrapper
res = handle_func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\core\management\commands\migrate.py", line 118, in handle
executor = MigrationExecutor(connection, self.migration_progress_callback)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\executor.py", line 18, in __init__
self.loader = MigrationLoader(self.connection)
~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\loader.py", line 58, in __init__
self.build_graph()
~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\loader.py", line 235, in build_graph
self.applied_migrations = recorder.applied_migrations()
~~~~~~~~~~~~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\recorder.py", line 89, in applied_migrations
if self.has_table():
~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\migrations\recorder.py", line 63, in has_table
with self.connection.cursor() as cursor:
~~~~~~~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 320, in cursor
return self._cursor()
~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 296, in _cursor
self.ensure_connection()
~~~~~~~~~~~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 279, in ensure_connection
self.connect()
~~~~~~~~~~~~^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\base\base.py", line 256, in connect
self.connection = self.get_new_connection(conn_params)
~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^
File "A:\all_for_project\.venv\Lib\site-packages\django\utils\asyncio.py", line 26, in inner
return func(args, kwargs)
File "A:\all_for_project\.venv\Lib\site-packages\django\db\backends\postgresql\base.py", line 332, in get_new_connection
connection = self.Database.connect(conn_params)
File "A:\all_for_project\.venv\Lib\site-packages\psycopg2\__init__.py", line 135, in connect
conn = _connect(dsn, connection_factory=connection_factory, *kwasync)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc2 in position 61: invalid continuation byte
Сделал проект, захожу заново и непоулчается, пробовал много чего. Разобрался как это делается через PowerShell, НО как блять это сделать просто в терминале Python? Без всякой магии и чего там. Основной код лежит в папке new_project, окружение в new_project\myenv. ОС window 11
\myenv\scripts\activate . если ругается .\activate
> 1) дженериковых типов нету в рантайме
Ты ведь понимаешь чем тайпинг от статической типизации отличается? Дам подсказку -- загугли что такое статический анализатор кода и чем он отличается от компилятора
>>397565
Там вроде бы тот же самый OAuth2.0, погугли гайды на эту тему
>>397620
Ну вроде же четко написано, что у тебя стринга коннекта кривая
>>397653
new_project\myenv\Scripts лежит куча файлов активаации для любого окружения. Батник для cmd, ps1 для повершела. Но блять вообще значит
> как блять это сделать просто в терминале Python
? Это что за набор слов вообще?
А ты кто вообще?
Иди нахуц, скот.
> в терминале python
Никак, венв это буквально отдельный экземпляр питона, изнутри запущенного питона ты это никак не сделаешь.
Поясните за дескрипторы, кто пользуется и в чём прикол?

На пике совет от него.
Что скажешь? Я уже хз, доверять ли ему?
А в чем у тебя конкретно трабл? Ты хочешь в обязательном порядке запрашивать или просто подключиться к сайту любым способом?
Дополни контекст правилами, которые ты нарушил, если они есть в письменном виде.
Может быть там есть что-то конкретное, например "нельзя отправлять более 1001 сообщений в час, иначе мы расценим это как флуд и отправим Вас в бан".
Или добавь причину бана, если тебе написали, в чём заключался твой "флуд".
И потом снова заставь ai-падавана с обновлённым контекстом поправить код.
крудоделы на связи с идеальным эндпоинтами, зашлифованными в сотнях промтах десятка нейронок. Есть что улучшить?
Аннотации типов где, макакич?
ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts.
httpx 0.23.3 requires httpcore<0.17.0,>=0.15.0, but you have httpcore 0.17.3 which is incompatible.
fastapi 0.101.0 requires starlette<0.28.0,>=0.27.0, but you have starlette 0.30.0 which is incompatible.
Вроде раньше когда-то такого не было. Или Python стал очередным языком с неразрешимыми зависимостями, скрипты на котором можно запускать только на машине, где их писали (как руби)?
Там же тебе написано, что версии пакетов нужны меньше чем установленные в системе
pip install -r requirements.txt в помощь, ну или через что там зависимости у тебя
ну и виртуальное окружение используй, а не с винды своей запускай
Легко. Без каких либо собеседований просим соискателя решить задачу и выслать решение в github. Задача такая - Допустим, есть у нас посты. У каждого поста может быть много репостов. И у репоста могут быть репосты, и так далее. Необходимо посчитать кол-во репостов каждого оригинального поста. В таблице лежат десятки миллионов записей.
Если у меня плохое настроение и припёрся соискатель вживую, то я обычно даю бумажку и карандаш и прошу написать функцию, которая инвертирует односвязный список.
Через пару недель приходит шеф и спрашивает, почему ещё никого не наняли ))
P.S. Что странно, когда я даю эти задачи соискателям на смежный Ruby проект, они, почему-то, решают их...
Так это просто алгосики аля яндекс, а конкретно знания питона на питонячьи вакансии вообще не проверяют что-ли?
Какая же хуета, господи. Какой-то нахуй фасад нагородили, это просто охуеть. Не пробовал загуглить что это нахуй значит, прежде, чем использовать? Ну и в голос с КОДОВ ОШИБОК нахуй, это уже совсем нахуй за гранью. Пиздец, уноси эту хуйню и переписывай заново
По разному, почти всегда просят написать декоратор с параметром и что-нибудь про индексы в бд спрашивают. А все остальное совершенно произвольное может быть от обсуждения системы коммитов в кафке и невозможности exactly once и до того, как gc работает в питоне(бтв довольно популярный вопрос, так как gc в питоне это не совсем тоже самое, что в других языках).
спасибо, учтём ваше карланское мнение, спасибо, что вы не с нами, не дай бох ) счастья здоровья
сразу видно отсталого, который в 2025 году ГУГЛИТ вопросы, а не ▓▓▓▓▓ их.
(Проверка подобность пациенту, пробел заполните сами)
> дедулай наебашил кодов ошибок и начал трястись, когда его отправили на порашу с этим говном
Наес
Таблетки
>
>Дипсик написал мне бота для пересылки сообщений из тг-каналов мне в лс и через некоторое время я словил бан за флуд на 40 дней.
>На пике совет от него.
>Что скажешь? Я уже хз, доверять ли ему?
Доверять ему? Да ты, бля, себе не доверяй, пока не научишься думать головой, а не жопой. Закрой рот, иди почитай документацию, и не позорься.

720x720, 0:07
Раньше он меня предупреждал даже когда я поставлю одну пустую строку между функциями, сейчас же просто молчит. Даже на длину строки ему наплевать. На всё стало наплевать. Он так сильно стал похож на VSCode, до блевоты просто.
Это же заточенный под Питхон инструмент, почему я должен лезть в настройки и выставлять всю эту блядоту как было, словно я в VSCode, который нужно выдрочить плагинами, прежде чем он начнет нормально работать. Да еще и искать где это было.
Может быть у анончика есть какой-то мануал, с помощью которого я могу поставить такие же настройки, как в прошлой версии PyCharm? Помоги пожалуйста.
А если изучать, то не будешь тупым ебанатом? это мерило?
Похоже, что у вас возникли проблемы с настройками инспекций и проверки кода в PyCharm Professional. Вероятно, после перехода на новую версию или смены редакции, настройки могли сброситься или измениться. Давайте попробуем восстановить функциональность, которая была в Community-версии.
### 1. Проверка включения инспекций PEP 8
- Перейдите в `File` → `Settings` (или `Ctrl+Alt+S`).
- В разделе `Editor` → `Inspections`.
- Убедитесь, что включена инспекция `PEP 8 coding style violation`. Она должна быть активна и настроена на ваш вкус (например, проверка длины строки, отступов, пробелов и т.д.).
### 2. Проверка настроек форматирования
- Перейдите в `File` → `Settings` → `Editor` → `Code Style` → `Python`.
- Убедитесь, что настройки форматирования соответствуют PEP 8. Например:
- `Hard wrap at` (длина строки) — обычно 79 или 120 символов.
- `Blank lines` — настройте количество пустых строк между функциями и классами.
### 3. Проверка включения автоматической проверки PEP 8
- Перейдите в `File` → `Settings` → `Tools` → `File Watchers`.
- Убедитесь, что у вас включен watcher для автоматической проверки PEP 8 (например, через `autopep8` или `flake8`).
### 4. Проверка использования внешних линтеров
- Если вы используете внешние линтеры (например, `flake8`, `pylint`), убедитесь, что они установлены и настроены в PyCharm.
- Перейдите в `File` → `Settings` → `Project` → `Python Interpreter`.
- Убедитесь, что нужные пакеты (`flake8`, `autopep8`, `pylint`) установлены.
- Затем перейдите в `File` → `Settings` → `Tools` → `External Tools` и настройте их использование.
### 5. Проверка настроек цветовой схемы
- Если подсветка ошибок и предупреждений пропала, возможно, проблема в цветовой схеме.
- Перейдите в `File` → `Settings` → `Editor` → `Color Scheme` → `General`.
- Убедитесь, что цвета для `Errors and Warnings` настроены и видны.
### 6. Сброс настроек (если ничего не помогает)
- Если ничего из вышеперечисленного не помогло, попробуйте сбросить настройки PyCharm:
- Закройте PyCharm.
- Удалите или переименуйте папку с настройками (обычно находится в `~/.config/JetBrains/PyCharm2024.3` на Linux или `~/Library/Application Support/JetBrains/PyCharm2024.3` на macOS).
- Запустите PyCharm снова — настройки будут сброшены до стандартных.
### 7. Проверка версии PyCharm
- Убедитесь, что вы используете актуальную версию PyCharm Professional. Иногда проблемы могут быть связаны с багами в конкретной версии. Попробуйте обновиться до последней версии.
Если после всех этих шагов проблема не решится, возможно, стоит обратиться в поддержку JetBrains или обсудить это на их форуме. Они обычно оперативно реагируют на такие запросы.
P.S. Если вам не нравится поведение PyCharm Professional, всегда можно вернуться к Community-версии — она бесплатна и имеет большинство необходимых функций для разработки на Python. 😊
Похоже, что у вас возникли проблемы с настройками инспекций и проверки кода в PyCharm Professional. Вероятно, после перехода на новую версию или смены редакции, настройки могли сброситься или измениться. Давайте попробуем восстановить функциональность, которая была в Community-версии.
### 1. Проверка включения инспекций PEP 8
- Перейдите в `File` → `Settings` (или `Ctrl+Alt+S`).
- В разделе `Editor` → `Inspections`.
- Убедитесь, что включена инспекция `PEP 8 coding style violation`. Она должна быть активна и настроена на ваш вкус (например, проверка длины строки, отступов, пробелов и т.д.).
### 2. Проверка настроек форматирования
- Перейдите в `File` → `Settings` → `Editor` → `Code Style` → `Python`.
- Убедитесь, что настройки форматирования соответствуют PEP 8. Например:
- `Hard wrap at` (длина строки) — обычно 79 или 120 символов.
- `Blank lines` — настройте количество пустых строк между функциями и классами.
### 3. Проверка включения автоматической проверки PEP 8
- Перейдите в `File` → `Settings` → `Tools` → `File Watchers`.
- Убедитесь, что у вас включен watcher для автоматической проверки PEP 8 (например, через `autopep8` или `flake8`).
### 4. Проверка использования внешних линтеров
- Если вы используете внешние линтеры (например, `flake8`, `pylint`), убедитесь, что они установлены и настроены в PyCharm.
- Перейдите в `File` → `Settings` → `Project` → `Python Interpreter`.
- Убедитесь, что нужные пакеты (`flake8`, `autopep8`, `pylint`) установлены.
- Затем перейдите в `File` → `Settings` → `Tools` → `External Tools` и настройте их использование.
### 5. Проверка настроек цветовой схемы
- Если подсветка ошибок и предупреждений пропала, возможно, проблема в цветовой схеме.
- Перейдите в `File` → `Settings` → `Editor` → `Color Scheme` → `General`.
- Убедитесь, что цвета для `Errors and Warnings` настроены и видны.
### 6. Сброс настроек (если ничего не помогает)
- Если ничего из вышеперечисленного не помогло, попробуйте сбросить настройки PyCharm:
- Закройте PyCharm.
- Удалите или переименуйте папку с настройками (обычно находится в `~/.config/JetBrains/PyCharm2024.3` на Linux или `~/Library/Application Support/JetBrains/PyCharm2024.3` на macOS).
- Запустите PyCharm снова — настройки будут сброшены до стандартных.
### 7. Проверка версии PyCharm
- Убедитесь, что вы используете актуальную версию PyCharm Professional. Иногда проблемы могут быть связаны с багами в конкретной версии. Попробуйте обновиться до последней версии.
Если после всех этих шагов проблема не решится, возможно, стоит обратиться в поддержку JetBrains или обсудить это на их форуме. Они обычно оперативно реагируют на такие запросы.
P.S. Если вам не нравится поведение PyCharm Professional, всегда можно вернуться к Community-версии — она бесплатна и имеет большинство необходимых функций для разработки на Python. 😊

640x360, 0:14

1280x1272, 0:07

360x640, 0:10

576x1024, 0:12
>### 1. Проверка включения инспекций PEP 8
Спасибо, анончик, как я не догадался сразу спросить у какой-нибудь гопоты, сейчас попробовал, она даже на мой оригинальный пост написала.
>Понимаю твоё раздражение — переход на новую версию PyCharm Professional 2024.3.2 явно подкинул неприятных сюрпризов с подсветкой PEP8
Держи котиков.

Спите и видите как получаете 300к наносек говнокодя на таком чудесном и простом языке как Питон.
А я вот сплю и вижу как выкатываюсь из этого чудо языка ибо заебало ходить по собесам и бороться за жалкие копейки с сотнями таких же неудачников.
10 лет опыта, знание сотен либ. базы, очереди, паттерны, микросервисы. Десятки прочитанных книг, куча интересных проектов в портфолио, опен сорс на гитхабе... И знаете что?
Меня нахер не завут на собесы даже за жалкие 250К вечно деревянных.
А на что вы надеетесь?
Вот я и принял решение перекатываться в другой язык. Да можно сейчас напрячься, доказать всему свету, что не слабак, найти очередную работу на питончике но через 1.5-2 года, когда я с нее уволюсь ситуация будет еще хуже и моя ЗП будет еще меньше. Так что питон это уже бесперспективная тема.
А знаете что? Это даже к лучшему, что Петухон погиб. На свете полно классных языков, которые учли ошибки своих предшественников и на них писать куда приятнее...

Мне вот любопытно. Только у меня PyCharm с версии 2024.3 проводит проверку на нарушения PEP 8, но никаких предупреждений не показывает (пик стронгли релейтед): Settings: Editor -> Inspections -> PEP 8 coding style violation (No highlighting)
Если это нововведение, то какой тогда интересно в этом смысл, чтобы не ебать мозги человеку, а просто все тихо чинить при Ctrl+Alt+L?

854x480, 0:17
> На свете полно классных языков, которые учли ошибки своих предшественников и на них писать куда приятнее...
Расскажи мне про язык на котором также приятно в нейросети, бэк, парсинг и решение разных рутинных задач.
> 10 лет опыта, знание сотен либ. базы, очереди, паттерны, микросервисы. Десятки прочитанных книг, куча интересных проектов в портфолио, опен сорс на гитхабе... И знаете что?
Сдается мне, что ты напиздюнькал нам, обманул, ввел в заблуждение, сказал неправду, не был с нами честным.

Проебал картинку

>Расскажи мне про язык на котором также приятно в нейросети, бэк, парсинг и решение разных рутинных задач.
ага, и в вакансия теперь тоже требуют и бэк и машинное обучение (и фронтенд в придачу), ну а хуле, язык то все позволяет, зачем нескольких специалистов нанимать, Антошка Сычев вон все сделает.
Только вот, что это совершенно разные области кабанчику пофиг.
>Сдается мне, что ты напиздюнькал нам, обманул, ввел в заблуждение, сказал неправду, не был с нами честным.
боюсь, что даже самую малость не наебал, как на духу все выложил, аки перед боженькой исповедался.
Хрюши давно сидят в ЦРМ-ках, которые собирают базу резюме, и в этой базе видно историю изменения резюме. А так же "отзывы" и дополнительные фильтры, чтобы автоматом отказывать.
talantix.ru, https://huntflow.ru/ да много их...
https://www.youtube.com/watch?v=b5tDa56GDmw&list=WL&index=12&ab_channel=%D0%90%D0%BD%D1%82%D0%BE%D0%BD%D0%9D%D0%B0%D0%B7%D0%B0%D1%80%D0%BE%D0%B2I%D0%9E%D1%81%D0%BE%D0%B7%D0%BD%D0%B0%D0%BD%D0%BD%D0%B0%D1%8F%D0%9C%D0%B5%D1%80%D0%BA%D0%B0%D0%BD%D1%82%D0%B8%D0%BB%D1%8C%D0%BD%D0%BE%D1%81%D1%82%D1%8C
Как ты с таким опытом и стеком не можешь найти даже 250к, когда я работая auto qa макакой со стеком pytest/grpc/selenium/requests/allure получаю 360? наебалово какое-то, либо тебе надо поправить резюме и прокачать скилл собесов.
Когда же до вас дойдет.. дело не в языке. Просто вас стало так дохуя, что работодателю нет теперь смысла платить тебе 250к. Желающих работать за 100 - сотни. Таких же как ты и даже лучше. И среди них выбирают.
Чекай что на рынке творится http://158.160.161.158/hh/
>Просто вас стало так дохуя
но не сразу понимаешь насколько дохуя. у меня буквально все знакомые скуфы понабрали кредитов и прошли питон курсы.
Вкатунам я искренее советую изучить, что на западе актуально и ТОЛЬКО НАБИРАЕТ популярность. и вкатываться туда. В Rust какой-нибудь или Zig или хуй знает во что еще.
Ну и конечно не забывать, что нейросети не дремлют и уже сейчас способные писать вполне себе большие куски кода лучше чем мидл разработчик.
А ты что думаешь? как дальше кодеркам выживать?
На западе пару лет назад толпы разработчиков выгнали нахуй на мороз, в том числе и пидорастеров из мозилы.
В отрасли кризис, она была изначально раздута как по штатам так и по капитализации, все последние года айти-сектор держался на сказках инфоцыган что вкладываю сюда вы вкладываете в гугл в 2001.

А я пока поделюсь с вами парочкой свежих Python вакансий за понедельник, 18 марта.
https://hh.ru/vacancy/118434433
https://hh.ru/vacancy/118433880
https://hh.ru/vacancy/118422437
>Вкатунам я искренее советую изучить, что на западе актуально и ТОЛЬКО НАБИРАЕТ популярность. и вкатываться туда. В Rust какой-нибудь или Zig или хуй знает во что еще.
Ебать дебил.
Казалось бы - серьезная компания не должна такой хуйней заниматься, у нее миллиардные обороты, что нельзя что ли 2 разработчиков нанять.
https://hh.ru/vacancy/118436422

Долго не мог понять почему мне отказывают и не зовут на тех собесы хотя я по навыком идеально подхожу и всего 250тр прошу...
Сегодня убрал зарплату в резюме и мне наконец ответили с Контура:
>Спасибо большое. Я хочу внести ясность отнсительно наших вилок. >Верхняя граница оклада сеньора 240 на руки + премии, в среднем по году >до 280 на руки. Но по нашей матрице верхняя граница сеньора - это >почти TechLed. Граница мидл+/сениор ЗП до 190 на руки, с премиями >средняя по году около 215.
Контур — экосистема для бизнеса. Наши сервисы помогают каждой третьей компании России делать рабочие процессы проще и эффективнее: вести бухгалтерию, сдавать отчетность в госорганы, обмениваться документами без бумаги, общаться друг с другом на удаленке и многое другое. С нами жизнь 2,5 млн предпринимателей и их сотрудников становится легче.
Вот такая маленькая и бедная компания Контур, понять и простить...
https://career.habr.com/companies/skbkontur
А нахуй ты там за 250 тыр нужен? Питонистов и жаваскриптеров на рынке как собак нерезанных, а рыночек айти в рф схлопывается и режется. Сеньки за 30 тыр за забором стоят, лучше их взять чем такого важного синьора как ты.
Да не перетолстил. Только сегодня обсуждал аутстафферские направления. На одну вакуху с распространными технологиями типа Реакта за час набирается 50 вакансий. Ждать что тебя охуенного примут и дадут 250к+ я бы не стал. Особенно без собственного бренда.
нет, это в стране мтс auto qa. 360 гросс.
Ну я вот на работе в процессе перехода с питона на гоуленг.
Думаю дело не в питоне, а в том, что бекенд на нем писать сложновато. Без pydantic+mypy проект становится говном буквально мгновенно. Потом его очень больно поддерживать. Я вот на поддержке питон легаси хуитки сидел и это полная параша. Динамикродрисня на бекенде это вообще зло я считаю.
Собственно поэтому сейчас все на гоуленге и жабе делается. Новых проектов в бекенде где-нибудь в бигтехе на питоне или ноде исчезающе мало. Но много помойного легаси, которое надо поддерживать или переписывать на что-то адекватное типизированное.
>>409505
Питон как раз хорош для универских лаб и курсачей. В универе я на нем делал практически все. Потому что очень быстро и удобно. Но для продовых решений в энтерпрайзе питон не годится, получается говно практически всегда и везде.
Да вот только говно и жаба - это два стула, ну и писать тырпрайз на говно, который вообще для другого это пиздец.

База анончик, вот я 7 лет назад по той же причине из PHP в Python перекатился. Теперь ситуация повторяется - теперь на Python в России мало новых проектов.
Сам уже 2 месяца вкатываюсь в гошечку. Очень нравится, особенно канкаренси по сравнению с питончиком как глоток свежего воздуха пива.
Сколько времени у тебя занял перекат и какой стек на проекте? Все на станддартных компонентах или используете орм\фремворки?
>
>Сколько времени у тебя занял перекат и какой стек на проекте
Мне прям на работе дали новый проект и сказали его на Го делать.
Перекат занял ну довольно мало, я го тур прошел за неделю, еще всякие материалы почитывал параллельно. Го довольно простой язык. Сложное в нем это наверное все что вокруг канкарренси, я его по верхам изучил и в кишки пока что еще не лез.
>>411675
>Все на станддартных компонентах или используете орм\фремворки
Да, по большей части все стандартное используем.
Фреймворки вроде gin и DI контейнеры по типу uber/fx не брали - все сами пишем. Используем обычный net/http вместе с chi. Орм еще не брали, используем сейчас sqlx + pgx для постгри. Может быть gorm попробуем затащить в один из микросервисов и в дальнейшем будем с ним жить.
Я начинал с Python crash course, нормальная книжка. Хотя, если есть кое-какой опыт, то возможно слишком нубская.
Я года 3 назад с неё начинал, щас уже вкатился.
С начала можешь любую книгу выбрать, я читал "Простой питон" так как Лутц дает слишком много подробностей и тонкостей, для новичка это лишнее.
А потом обязательно эти две.
Писать с нуля на Джанго точно не хочу, тк хуёво шарю во фронте. Думаю взять готовую CMS, а в ней уже потом допиливать нужные свисто-перделки.
Что лучше взять? Вроде как везде хвалят wagtail. А еще есть django cms, она вроде мощнее и больше свободы, но по ней в разы меньше документации.
Это для совсем вкатыша ты такие книги выбрал? Давай тогда сразу завтра ищешь в интернете книжку Dive into python. Пофиг если ничего не поймешь. Затем идешь на python.org и изучаешь стандартную библиотеку от корки до корки. Потом зубришь, именно, сука, вызубриваешь конвенцию по написанию питоньего кода - PEP8, чтобы от зубов отскакивало. Когда напишешь свою первую имиджборду, по пути изучив верстку на html+css, скачиваешь и изучаешь любой питоний асинхронный вебсервер, рекомендую Tornado или Gevent. Как переделаешь имиджборду, чтобы выдавала по крайней мере 5 тысяч запросов в секунду, можешь идти дальше - тебя ждет увлекательный мир хайлоада. Apache Hadoop, сверхбыстрые асинхронные key-value хранилища, MapReduce. Отсос хиккующих выблѣдков / просто неудачников типа рейфага или сисярп/джава-удососов, которые сосут уд по жизни не заставит себя ждать и уже через пол года ты будешь получать такие суммы, что любая баба будет течь при одном упоминании твоей зарплаты.
А зачем? В шараге учил, что-то даже писал уровня калькулятора, но нахуй он пошел из моей головы.
Ты сам написал
>для совсем вкатышей
Паскаль решает конкретную проблему - обучение программированию. Питон решает другую(е) проблему(ы), питон тебе не нужен.
Ну хз, вкатываюсь третий месяц пока 438 запросов в секунду. Думаю для небольшой борды вполне сойдет.
А нахуя? Почему нельзя ПРОСТО прописать так, как предлагается в доке? В этом есть какой-то практический смысл?
>По разному, почти всегда просят написать декоратор с параметром и что-нибудь про индексы в бд спрашивают.
Литералли то же самое, что у меня на джуна спрашивают на собесах.
так эндпоинты пишут милорды синьоры, наберись опыта, подучись и всё поймёшь.
Но судя по лексике ты в IT недавно, так что, как говорится, "караван идёт, а собаки лают".
начни с PEP 20
Потому что писал обезумевший от паттернов и солида клинкодокретин. За такую хуйню в нормальной команде переломают колени и отправят переписывать
это нужно чтобы не создавать внешних переменных, коротким способом.
def say_hi_once()[done: False]:
if not done:
done = True
print("hi")
x=0
n = input("Enter n:")
for i in n:
x=(x+33000)*1.0167
print(x)
Конечно! Ваш код имеет несколько ошибок, которые нужно поправить, чтобы он работал корректно:
input() возвращает строку, а нужно число.
Переменная n используется в цикле for, но вы хотите повторить цикл n раз — значит, нужно привести n к int.
Внутри цикла нужен отступ.
Комментарии или пояснение могут помочь "домохозяйке" разобраться, что происходит.
Вот исправленный и понятный вариант:
x = 0
n = int(input("Введите количество месяцев: "))
for i in range(n):
(отступ)x = (x + 33000) * 1.0167 # добавляем 33000 и прибавляем 1.67% ежемесячно
print(f"Итоговая сумма: {x:.2f} руб.")
Пример:
Если ввести 12, то это значит "в течение 12 месяцев мы добавляем по 33000 и начисляем 1.67% ежемесячно".
Если что-то нужно упростить или сделать интерфейс ещё понятнее — могу помочь.
Благодарю за предоставленный ответ! Ваше пояснение оказалось весьма полезным: вы корректно указали на необходимость приведения input() к int, добавления отступа в теле цикла и уточнили логику расчёта. Также ценю комментарии, поясняющие происходящее в коде — это действительно помогает лучше понять процесс. Спасибо за помощь!
нет
Проблема такая: есть Python приложуха на Гитхабе, которую я хочу установить. Она подтягивает зависимости через pip. Однако мне важно, чтобы она была полностью самодостаточна, чтобы рут папку можно было переименовать или перенести по новому пути, на новый компьютер, без дозагрузок через pip. Какой лучше подход использовать? Пробовал создавать venv и устанавливать все туда, но там суровый хардкод путей. Даже вручную пути заменял все, все равно что-то ломается. Пробовал создавать новый venv, переносить туда папку Lib из старого, но тоже что-то не так. Походу нужно как-то каждый pip package заново устанавливать в новую директорию, а не просто файлы мигрировать. Что делать, куда копать? Буду рад, если выручите, а то я уже голову сломал. В идеале вообще батник какой-нибудь собрать, который будет "мигрировать" venv с одного пути на другой и пересобирать всё как надо.
То что ты ищешь скорее всего называется Nuitka и позволяет запаковать приложение как бинарник.
Если хочется избежать, то можно попробовать uv, но не обещаю что получится.
С бинарником сразу мимо, ибо важно оставить файловую архитектуру как она есть и есть возможность пуллить приложуху с Гитхаба. Про uv сейчас почитаю, спасибо.
посмотри, как реализовано в питон-дистрибутиве yt-dlp.
Надо ж быть такими ебанутыми.
Все сколь-нибудь серьезные языки программирования чувствительны к регистру, добро пожаловать.
Проиграл
> И какого хуя они зависят от регистра? Вот в том же Powershell
Виндоадминство до добра не доводит
Есть таблица SQL, всего на 7 строчек.
Создал функцию (собственную, def).
Таблица SQL - это исходные данные для этой функции.
С помощью multiprocessing запустил параллельно 7 процессов (то есть как бы 7 экземпляров моей функции), но из 7 строчек исходной таблицы тот процесс, который соответствует строчке с id = 7 ниху не робит. А когда его отдельно запускает - то все окей. Блять ума не приложу, перегуглил все че можно нах. Как такое может быть? Если этот процесс в одиночку запускать, то все ок. В функции ошибки быть не может, ведь она единая для всех процессов
Ты прав, что данный код исповедует и solid и применяет паттерны и это python style вменяемых кодеров, что для обычных нормальных команд в твоём заштатном мирке, это предел понимания.

Недавно был на собесе и лид сказал, что он терпеть не может хранимые процедуры и на проекте их быть не должно.
А теперь я задумался, а что тогда делать есть нужна транзакция с несколькими запросами, ведь делать такое на стороне бекенда означает пиздец производительности:
1 накладные расходы на ввод вывод между бд и бэком.
2 в точках await происходит прерывание и пока корутина не возобновит работу транзакция простаивает блокируя строки в бд.
Или я не прав и сплошь и рядом транзакции пишут на стороне бекенда?
(на сам псевдокод внимания не обращайте, он нужен только для демонстрации концепции).
Транзакция должна вызываться за один запрос.
Если у тебя в бд есть хранимка, что мешает ее запрос разом послать, без промежуточных получения данных и новых запросов?
Транзакция, в которой бек получает промежуточный запрос и отправляет следующий в рамках одной транзакции, это конечно срань какая то.
>в точках await происходит прерывание и пока корутина не возобновит работу транзакция простаивает блокируя строки в бд.
Ну так ты несколько обработчиков питона запускай. У тебя один сервер что-ли?
"лид" прав в том, что хранимые процедуры создают горячее немасштабируемое место в районе сервера БД, а вот масштабирование бэнкедов более-менее подъемное и встречающееся дело.
С другой стороны, может он просто не знает pl/sql
>в точках await происходит прерывание и пока корутина не возобновит работу транзакция
Кстати, тут ты не прав. Залипание транзакции возникает на сетевом вызове, так что никаких проблем с масштабированием не будет. Если ты конечно все технологично написал и юзаешь библиотеку с поддержкой async io
напиши подробнее, что ты имеешь в виду?
в чем конкретно я не прав?
ты утверждаешь, что прерывание корутины не замедляет транзакцию?
да, вот мне тоже кажется, что срань.
>Ну так ты несколько обработчиков питона запускай. У тебя один сервер что-ли?
так проблема не в простое бекенда, а в простое базы.
из-за общения с бекендом записи в базе долго остаются заблокированными.
смысл в том, чтобы транзакция как можно быстрее выполнялась. Особенно это важны когда изоляция репитебл рид или сериалайзабл.
Ввел "n". Твои действия?
Есть главная программа, которая порождает процессы(через multiprocessing) и она должна ИНОГДА прослушивать, нет ли от них сообщений(через Pipe), а также иногда сама отправлять какие-то команды эти процессам. Но эта "главная программа" также должна слушать запросы по REST API, и реагировать на них. Проблема заключается в том, что во всех этих фреймворках есть главный цикл, где и происходит все основное для этих фреймворков, а мне надо, чтобы (пик1) тоже мог опрашивать процессы/отправлять им данные и тд. Вот например(пик2) во Flask, просто есть метод которые вызывается, когда запрос является "/", я никак не могу тут дополнительно прослушивать дочерние процессы и тд
получается мне надо свою миниреализацию через сокеты и socket.poll() делать или как? Надеюсь понятно выразился, сложно такое объяснить
Пусть рест запросы тоже в очередь пишут (в редис например или реббит) и главная программа читает в бесконечном цикле из этой очереди и пишет в пайпы. Можешь какой нибудь миделвере сделать чтобы данные по каждому рест запросу срать в очередь.
а если производительность не важна и ты не будешь масштабировать рест хендлеры то можешь на asyncio сделать, там и процессы можно ждать с await.
> Ну и в дата саенсе используется, но как дополнительный инструмент
А это не с любым языком так? Ну в смысле что изучать надо не язык, а какую-то область, в которой этот язык - инструмент?
мимо data-инженегр