invoke.context.Context дает странную ошибку для пропущенного позиционного аргумента - PullRequest
1 голос
/ 09 мая 2019

Я пытаюсь изменить каталоги в моей программе на Python в контекстном менеджере. использование invoke.context.Context кажется правильным способом, полученным из документации Fabric, и использование обычного with os.chdir не будет работать.

Однако, когда я пытаюсь сделать что-то вроде

from invoke import Context

with Context.cd("/etc"):
    subprocess.run(["ls"])

Я получаю сообщение об ошибке:

---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-2-40b28af3213a> in <module>
----> 1 with Context.cd("/etc"):
      2     subprocess.run(["ls"])
      3

~/miniconda3/envs/python3/lib/python3.7/contextlib.py in helper(*args, **kwds)
    237     @wraps(func)
    238     def helper(*args, **kwds):
--> 239         return _GeneratorContextManager(func, args, kwds)
    240     return helper
    241

~/miniconda3/envs/python3/lib/python3.7/contextlib.py in __init__(self, func, args, kwds)
     80
     81     def __init__(self, func, args, kwds):
---> 82         self.gen = func(*args, **kwds)
     83         self.func, self.args, self.kwds = func, args, kwds
     84         # Issue 19330: ensure context manager instances have good docstrings

TypeError: cd() missing 1 required positional argument: 'path'

В документации это кажется правильным (http://docs.pyinvoke.org/en/latest/api/context.html#invoke.context.Context),, но я немного растерялся.

Любой совет полезен.

1 Ответ

3 голосов
/ 09 мая 2019

Глядя на документацию, кажется, что вы должны создать свой собственный экземпляр Context вместо непосредственного использования класса Context.

Они также используют метод run() дляэкземпляр контекста вместо subprocess.run().

Попробуйте это:

from invoke import Context

c = Context()
with c.cd("/etc"):
    c.run("ls")
...