Мы уже знаем, что на текущую сессию интерпретатора изменение PYTHONPATH никак не повлияет. Но если вы запустите дочерний процесс, то он унаследует окружение текущего процесса, а значит и изменения в любых переменных будут на него влиять.
Вот небольшой пример:
Объявляем переменную
user@host:~$ export PYTHONPATH=/path1
Запускаем интерпретатор
user@host:~$ python3
Проверим что в sys.path
>>> import sys
>>> print(sys.path)
['', '/path1', '/usr/lib/...', ...]
Добавляем что-то в переменную
>>> import os
>>> os.emviron['PYTHONPATH'] = '/path1:/path2'
>>> print(sys.path)
['', '/path1', '/usr/lib/...', ...]
Изменений нет. Но давайте запустим дочерний процесс и посмотрим там
>>> os.system('python3')
# теперь мы находимся в другом процессе
>>> import sys
>>> print(sys.path)
['', '/path1', '/path2', '/usr/lib/...', ...]
Тоже самое будет и с subprocess, так как по умолчанию текущее окружение тоже наследуется.
>>> import subprocess
>>> subprocess.call(['python3', '-c', 'import sys;print(sys.path)'])
['', '/path1', '/path2', '/usr/lib/...', ...]
______________________
Лучшей практикой является передача энвайронмента явно через аргумент env!
import subprocess
subprocess.call(cmd, env={'PYTHONPATH': '...'})
Это поможет точно понимать какое окружение будет у запускаемого процесса и при этом не изменять окружение текущего процесса.
#basic
UX dizayn ortidagi haqiqat...
UX dizayn – bu faqat chiroyli ko‘rinish emas, balki foydalanuvchi ehtiyojlariga moslab ishlab chiqilgan tizimli yondashuv. Har bir tugma, sahifa oqimi, joylashuv — bular ortida logika, tahlil va tajriba yotadi.
Yaxshi UX dizayn bo‘lsa:
1. Platformaning struktura va navigatsiyasi aniq bo‘ladi,
2. Foydalanuvchi chalkashmaydi,
3. Dasturchi aniq yo‘l-yo‘riq bilan ishlaydi,
4. Ishlab chiqish jarayoni tezlashadi, xatolar kamayadi,
5. Va nihoyat, mahsulot muvaffaqiyatli chiqadi.
Shuning uchun UX dizayn — sarmoya hisoblanadi. Va bu xizmat arzon bo‘lishi kutilmasligi lozim. Chunki u platformaning asosiy poydevorini tashkil qiladi.
UX bo‘lmasa nima boʻlardi:
— Foydalanuvchi chalkashadi: sayt tushunarsiz bo‘ladi;
— Dasturchi yo‘nalishsiz ishlaydi: strukturani tuzishga qiynaladi va yana ham koʻproq toʻlov soʻraydi.
— Koʻproq vaqt sarflanadi: Kutilgan natijaga erishish uzoq vaqt talab qilishni boshlaydi.
Qisqasi: UX yo‘q joyda, muammo tug‘iladi.
Startup va bizneslar UXʼsiz zararga tushishganliklari haqida kelgusi postlarda yozaman.
@suxrobblog
#ux#mavzu#muammo
Five Why (Besh nima uchun) texnikasi
Bu muammoning asl sababini aniqlash uchun ishlatiladigan tahlil usuli. Bu metodika Sakichi Toyoda tomonidan ishlab chiqilgan va Toyota ishlab chiqarish tizimida keng qo‘llanilgan.
Five Why qanday ishlaydi?
— Ushbu usul muammoni chuqur tahlil qilish uchun "Nima uchun?" savolini besh marta berish orqali asosiy sababni topishga asoslanadi. Har bir javob keyingi "Nima uchun?" savoliga yo‘l ochadi.
Misol uchun muammo:Mijozlar veb-saytdan mahsulot sotib olmayapti.
1. Nima uchun? – Chunki ular to‘lov jarayonini yakunlamayapti.
2. Nima uchun? – Chunki to‘lov formasini to‘ldirish juda uzoq davom etmoqda.
3. Nima uchun? – Chunki forma juda ko‘p maydonlarni talab qiladi.
4. Nima uchun? – Chunki biz mijozlardan keraksiz ma’lumotlarni ham so‘rayapmiz.
5. Nima uchun? – Chunki biz foydalanuvchilar tajribasini optimallashtirish ustida ishlamaganmiz.
Natijada asosiy muammo kelib chiqdi – foydalanuvchi tajribasi yaxshi optimallashtirilmagan, shuning uchun to‘lov jarayoni murakkab bo‘lib qolgan. Endi yechim sifatida to‘lov shaklini soddalashtirish tavsiya etiladi.
Bu metod har xil sohalarda – biznes, dizayn, muhandislik va menejment kabi sohalarda qo‘llaniladi.
@suxrobblog
#fivewhy#ux#muammo
Murakkab hayotni yanada murakkablashtirmang. Yechimlarda maksimal minimallashtirishga harakat qiling.
"Bu element nega kerak, shuni qo'ymasa nima bo'ladi..." degan savollarni o'zingiz va mijoz (kompaniya)ga bering. Userni o'zini muammolari ko'p sizni va mijozingizni xohishini deb, yanada murakkablik ichiga tushib qolmasin...
@suxrobblog
» #muammo#murakkab#yechim