This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author lucca.ruhland
Recipients docs@python, lucca.ruhland
Date 2020-09-01.08:33:31
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1598949211.7.0.649344000832.issue41684@roundup.psfhosted.org>
In-reply-to
Content
When parsing arguments with a namespace object, the subparser are behaving different than the main parser, although this is not stated in the documentation.

Each attribute which is not already part of the namespace, should be saved into the namespace object.
Therefore any already existing namespace attribute should overwrite the default value of any argument which is not explicitly set. 

While this is true for the parent parser, it does not work for the subparser.
Here is a small example code:
------------------------------------------------------------------------
import argparse

parser = argparse.ArgumentParser()
parser.add_argument('--root', type=str, default='.')
subparsers = parser.add_subparsers()
subparser = subparsers.add_parser('subp')
subparser.add_argument('--subroot', type=str, default='./subdir')
our_args = argparse.Namespace(root="./config_root", subroot="./config_subdir")

argv = ['subp']
args = parser.parse_args(argv, namespace=our_args)
print(args)
------------------------------------------------------------------------
>>> Expected: Namespace(root='./config_root', subroot='./config_subdir')
>>> Output: Namespace(root='./config_root', subroot='./subdir')

When calling the subparser, the namespace attribute is overwritten by the default value.
History
Date User Action Args
2020-09-01 08:33:31lucca.ruhlandsetrecipients: + lucca.ruhland, docs@python
2020-09-01 08:33:31lucca.ruhlandsetmessageid: <1598949211.7.0.649344000832.issue41684@roundup.psfhosted.org>
2020-09-01 08:33:31lucca.ruhlandlinkissue41684 messages
2020-09-01 08:33:31lucca.ruhlandcreate