Како добити тренутни радни именик у Питхону

How Get Current Working Directory Python



Име датотеке или фасцикле може се користити са пуном путањом или само поменути назив датотеке или фасцикле само за употребу у скрипти. Пуна путања датотеке или фасцикле из коренског директоријума је наведена апсолутном путањом. Када се назив датотеке користи без имена путање у скрипти, тада се Тренутни радни именик претпоставља као име путање датотеке и назива се релативна путања. У Питхону је тренутни радни именик постављен на локацију директоријума одакле се извршава питхон скрипта. Многи модули постоје у питхону да би добили тренутни радни директоријум. Начини за преузимање тренутног радног именика коришћењем различитих модула у Питхону приказани су у овом водичу.

Пример-1: Коришћење патхлиб модула за добијање тренутног радног именика

Класа путање модул патхлиб користи се за читање тренутног радног именика извршне скрипте. Направите питхон скрипту са следећим кодом за читање и штампање тренутног радног именика помоћу модула патхлиб. Тхе цвд () метод класе Патх користи се за штампање тренутног радног именика из којег се скрипта извршава.







# Увезите путању из модула патхлиб

фромпатхлибувозПатх

# Преузмите путању тренутног радног именика

тренутни_радни_директоријум=Патх.цвд()

# Одштампајте локацију тренутног радног именика

принт('Локација тренутног радног именика је:')

принт(тренутни_радни_директоријум)

Излаз:

Следећи излаз ће се појавити након извршавања горње скрипте. Овде је путања тренутног радног именика без имена скрипте приказана у излазу.





Пример-2: Употреба нормпатх () и абспатх () за добијање тренутног радног именика

Коришћење ос модула је још један начин за преузимање тренутног радног именика. У класи путање ос модула постоје различите методе за преузимање тренутног радног именика. Нормпатх () и методе абспатх () су њих двоје. Ове методе враћају тренутни радни директоријум као низ. Направите питхон датотеку са следећом скриптом да бисте проверили сврхе ових функција.





# Увези ос модул

увоз ти

# Одштампајте тренутни радни директоријум помоћу функције нормпатх ()

принт('Тренутни радни директоријум (користећи нормпатх ()) је:')

принт(ти.пут.дирнаме(ти.пут.нормпатх(__филе__)))

# Одштампајте тренутни радни директоријум помоћу функције абспатх ()

принт(' нТренутни радни директоријум (користећи абспатх ()) је: ')

принт(ти.пут.абспатх('.'))

Излаз:

Следећи излаз ће се појавити након извршавања горње скрипте. Овде је путања тренутног радног именика без имена скрипте приказана у излазу.



Пример-3: Употреба реалпатх () за добијање тренутног радног именика

Тхе реалпатх () је још један начин за преузимање тренутног радног именика. Направите питхон датотеку са следећом скриптом да бисте одштампали тренутни радни директоријум са именом скрипте помоћу метод реалпатх () . У сценарију је потребно __филе__ као вредност аргумента која садржи име путање датотеке у коју се увози ос модул.

# Увези ос модул

увоз ти

# Прочитајте тренутни радни директоријум користећи функцију реалпатх ()

реал_патх= ти.пут.реалпатх(__филе__)

# Одштампајте тренутни радни директоријум са именом скрипте

принт(' нТренутни радни директоријум са именом скрипте је: ')

принт(реал_патх)

Излаз:

Следећи излаз ће се појавити након извршавања горње скрипте. Овде је путања тренутног радног именика са именом скрипте приказана у излазу.

Пример 4: Употреба гетцвд () за добијање тренутног радног именика

Помоћу функција гетцвд () ос модула је најједноставнији начин за преузимање тренутног радног директоријума извршне скрипте. Не садржи ниједан аргумент и враћа ЦВД као низ. Направите питхон датотеку са следећом скриптом да бисте проверили употребу функција гетцвд () . Тренутни радни директоријум се штампа на почетку скрипте. Затим се тренутна путања директоријума мења помоћу функција цхдир () . Тхе наредба гетцвд () се поново позива након промене именика.

# Увези ос модул

увоз ти

# Одштампајте тренутни радни директоријум помоћу функције гетцвд ()

принт(„Тренутни радни именик је: н', ти.гетцвд())

# Промените тренутни радни директоријум

ти.цхдир(' / етц / маил')

# Одштампајте тренутни радни директоријум након промене

принт(' нТренутни радни директоријум након промене је: н', ти.гетцвд())

Излаз:

Следећи излаз ће се појавити након извршавања горње скрипте. Овде је тренутна путања радног директоријума без имена скрипте одштампана пре промене директоријума. Затим је одштампана промењена путања директоријума.

Пример-5: Употреба гетцвд () са три-екцепт за добијање тренутног радног именика

Направите питхон датотеку са следећом скриптом да бисте променили тренутни радни директоријум на основу улазне вредности и решили различите врсте грешака. Извођењем скрипте могу се решити три врсте грешака. Тхе Грешка ФилеНотФоундЕррор ће бити генерисано ако путања преузета са улаза не постоји. Тхе Грешка НотАДирецториЕррор ће бити генерисано ако путања преузета из уноса није директоријум. Тхе Грешка ПермиссионЕррор ће се генерисати ако путања преузета са улаза није доступна.

# Увезите ос модул

увоз ти

# Унесите путању до директоријума

цвд= улазни('Унесите путању тренутног радног именика: н')


покушати:

# Промените тренутни радни директоријум

ти.цхдир(цвд)

# Одштампајте тренутни радни директоријум помоћу функције гетцвд ()

принт(„Тренутни радни именик је: н', ти.гетцвд())

# Повећајте грешку ако директоријум не постоји

осимФилеНотФоундЕррор:

принт('Именик не постоји.')

# Повећајте грешку ако улазна путања није директоријум

осимНотАДирецториЕррор:

принт('%с није директоријум'%(цвд))

# Повећајте грешку ако директоријум није доступан

осимГрешка дозволе:

принт('Дозвола за промену именика одбијена.')

Излаз:

Следећи излаз ће се појавити након извршавања горње скрипте ако путања постоји. Овде постоји заузета улазна путања, а измењени радни директоријум је одштампан у излазу.


Следећи излаз ће се појавити након извршавања горње скрипте ако путања не постоји.


Следећи излаз ће се појавити након извршавања горње скрипте ако изабрана путања није доступна.

Закључак:

Коришћење патхлиб и ос модула за читање тренутног радног именика приказано је у овом водичу коришћењем различитих примера. Начин преузимања тренутног радног именика након промене тренутног радног именика на основу уноса корисника такође је приказан у овом водичу.