Наверняка вы замечали, что в Python есть удобная функция для получения переменной окружения
os.getenv(NAME)
И её "сестра" для создания или изменения переменных окружения
os.putenv(NAME, VALUE)
Но почему-то putenv() не работает как должно. Энвайромент не обновляется!
os.putenv('MYVAR', '1')
print(os.getenv('MYVAR'))
... и ничего 😴
Почему так?
На самом деле энвайромент обновляется, но это значение не добавляется в словарь os.environ.
Откройте исходник функции os.getenv(). Это просто шорткат для os.environ.get()
В то время как putenv() это built-in С-функция.
Словарь os.environ (или точней класс из MutableMapping) создаётся из энвайромента в момент инициализации. Функция putenv() самостоятельно его не изменяет.
В тоже время, когда вы создаёте или изменяете ключ в os.environ, автоматически вызывается putenv() в методе __setitem__().
То есть, технически putenv() всё делает верно, но в os.environ это не отражается. Можно проверить так:
>>> os.putenv('MYVAR', '123')
>>> os.system('python -c "import os;print(os.getenv(\'MYVAR\'))"')
123
Я объявил переменную в текущем процессе и вызвал дочерний процесс, который её унаследовал и получил в составе os.environ.
Аналогично при удалении переменной вызывается еще одна built-in функция unsetenv(), удаляющая переменную из системы.
Итого
▫️ Удобней всего явно обновлять переменные через os.environ
▫️ Есть способ неявно создать/удалить переменную через putenv/unsetenv, что не повлияет на os.environ но изменит энвайромент и передаст изменения сабпроцессам. Но так лучше не делать!
▫️os.environ это просто обертка для built-in функций putenv() и unsetenv().
#basic
🇷🇺#RASP
Российские активы Evraz Plc с 1 апреля переведены на ПАО "Евраз"
Всего ПАО "Евраз" объединит около 60 юридических лиц, которые сохранят свои названия и продолжат операционную деятельность в качестве его дочерних обществ.
В ноябре прошлого года "Евраз КГОК" получил разрешение на совершение сделки, в результате которой он станет владельцем 93,2% акций угольной ПАО "Распадская"
mt в max
МНЕНИЕ: Мы не ожидаем рекомендации дивидендов Распадской за 2025 г. на фоне операционной убыточности и корпоративных изменений — ИК ВЕЛЕС Капитал #RASP
Читать далее
👉https://smartlab.news/i/180114
мы в max
Распадская отчёт РСБУ за I кв 2026 года:
📉 Выручка ₽4,6 млрд (₽5 млрд за I кв 2025 года), снижение на 8,6%
📉 Чистая прибыль ₽73,6 млн (₽393,5 млн в I кв 2025 года), снижение в 5,3 раза #RASP
Читать далее
👉https://smartlab.news/i/188153
мы в max
Распадская МСФО 2025 год:
📉Выручка ₽116,9 млрд (-26,4% г/г)
📉Убыток ₽53 млрд против убытка ₽11,8 млрд годом ранее
Читать далее
👉https://smartlab.news/i/180120
#RASP
🪨#rasp
Сегодня не добив до верха канала цена акции ушла на коррекцию.
В результате достигнут низ канала, откуда пытаемся отскочить.
☄️При очередном касание низа канала 161.55 буду брать лонг.
✅Тэйк - 168 (середина канала)
🔻Стоп-лосс - 158.5 (под минимум прошлого импульса)
Не иир
🪨#RASP
1/3 позиции зафиксирую.
Прибыль +1,5%✅
Стоп переставлю в безубыток.
Идея здесь: https://t.me/privatka_Kazakova/3255
Хотите больше таких идей? Ставим 100👍, и я готовлю новые идеи
Не иир
🪨#RASP (Распадская)
💥Беру от текущих 216.52 на отскок.
🤔Сегодня наблюдаем пробой вниз сильного уровня поддержки, стопы сняли, шортистов посадили на ложном пробое и вернулись над поддержку (синяя горизонтальная линия).
✅Цель - 230 (ретест снизу синей нисходящей линии)
🔻Стоп лосс на минимум сегодняшней сессии 211.8
Входим?
Да, откупаю - 👍
Нет, сижу на заборе - 🔥
Не иир