python变量域名_【已解决】python中枚举(enumerate/iterate)域名(namespace)变量

【问题】

已经获得了对应的namespace的变量:newParser = argparse.ArgumentParser();

newParser.add_argument("-u", "--username", dest="username_argparse", help="Your user name");

newParser.add_argument("-a", "--age", type=int, dest="age_argparse", help="Your age");

args = newParser.parse_args();

print "args=",args; #args= Namespace(age_argparse=1000, username_argparse='crifanLi')

print "type(args)=",type(args); #type(args)=

现在想要能够枚举其中的args变量,获得其中的key,即age_argparse和username_argparse。

【解决过程】

1.找了半天,

最终是参考:

使用__dict__的方式newParser = argparse.ArgumentParser();

newParser.add_argument("-u", "--username", dest="username_argparse", help="Your user name");

newParser.add_argument("-a", "--age", type=int, dest="age_argparse", help="Your age");

args = newParser.parse_args();

print "args=",args; #args= Namespace(age_argparse=1000, username_argparse='crifanLi')

print "type(args)=",type(args); #type(args)=

argsDict = args.__dict__;

print "parsed argsDict=",argsDict; #parsed argsDict= {'age_argparse': 1000, 'username_argparse': 'crifanLi'}

然后再通过argsDict.keys()就可以得到对应的key了。

2. 另外也参考:

知道了,也可以通过vars()的方式:newParser = argparse.ArgumentParser();

newParser.add_argument("-u", "--username", dest="username_argparse", help="Your user name");

newParser.add_argument("-a", "--age", type=int, dest="age_argparse", help="Your age");

args = newParser.parse_args();

print "args=",args; #args= Namespace(age_argparse=1000, username_argparse='crifanLi')

print "type(args)=",type(args); #type(args)=

argsDict = args.__dict__;

print "parsed argsDict=",argsDict; #parsed argsDict= {'age_argparse': 1000, 'username_argparse': 'crifanLi'}

argsVars = vars(args);

print "argsVars=",argsVars; #argsVars= {'age_argparse': 1000, 'username_argparse': 'crifanLi'}

获得对应的dict变量。

3.另外也参考比人中提到的,官网的解释:

再次知道了vars。

【总结】

对于namespace的args,可以通过args.__dict__或者vars(args)的方式,获得对应的dict类型的argsDict变量,然后就可以再去枚举,获得对应的key(和value)了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python枚举函数enumerate()是一个内置函数,它将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,并同时列出数据和数据下标,通常用在for循环。该函数返回一个enumerate对象,是一个可迭代对象,通过遍历可以获取具体的元素值。它的语法为:enumerate(iterable, start),其iterable是可遍历的对象,start是索引的起始值,默认为0。使用enumerate函数可以在for循环同时获取索引和值。 这个函数在字典上也可以使用,表示枚举或列举的意思,用于获取字典的键和值。对于一个可迭代的对象,可以使用enumerate函数将其组合为一个索引序列,从而在for循环获得计数的效果。 一个例子是可以利用enumerate()函数和for循环来遍历文件的每一行,并同时获得行号和行内容。例如,可以使用以下代码来读取一个文件,并在遍历每一行的同时记录行号: count = 0 for index, line in enumerate(open(filepath,'r')): count += 1 这样就可以在count变量获得文件的行数,index变量获得行号,line变量获得每一行的内容。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python 使用enumerate()函数详解](https://blog.csdn.net/jh035/article/details/128077895)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [python enumerate用法总结](https://blog.csdn.net/churximi/article/details/51648388)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值