我正在使用Google的Python API来下拉审核信息,但我无法获得argparse的父组参数(这似乎是API访问所必需的)和我自己的参数(例如,传递在一个日期)一起工作。在谷歌管理API中使用Argparse
代码:
import pprint
import sys
import re
import httplib2
import json
import collections
import argparse
from oauth2client import client
from apiclient import sample_tools
from apiclient import discovery
from oauth2client.client import AccessTokenRefreshError
from oauth2client.client import OAuth2WebServerFlow
from oauth2client.file import Storage
from oauth2client.tools import run
from oauth2client import tools
def main(argv):
# Parser for command-line arguments.
parser = argparse.ArgumentParser(
description=__doc__,
formatter_class=argparse.RawDescriptionHelpFormatter,
parents=[tools.argparser])
parser.add_argument("-d","--selected_date", help="Date (YYYY-mm-dd) to run user usage report", required=True)
args = parser.parse_args(argv[1:])
print args
selected_date = args.selected_date
print selected_date
# Authenticate and construct service.
service, flags = sample_tools.init(
argv, 'admin', 'reports_v1', __doc__, __file__,
scope='https://www.googleapis.com/auth/admin.reports.usage.readonly')
# If the Credentials don't exist or are invalid run through the native client
# flow. The Storage object will ensure that if successful the good
# Credentials will get written back to a file.
storage = Storage('admin.dat')
credentials = storage.get()
if not credentials or credentials.invalid:
credentials = run(FLOW, storage)
而且在命令行中运行它...
> python user_report.py
usage: user_report.py [-h] [--auth_host_name AUTH_HOST_NAME]
[--noauth_local_webserver]
[--auth_host_port [AUTH_HOST_PORT [AUTH_HOST_PORT ...]]]
[--logging_level {DEBUG,INFO,WARNING,ERROR,CRITICAL}] -d
SELECTED_DATE
user_report.py: error: argument -d/--selected_date is required
看起来不错那么远,现在加上参数
> python user_report.py -d "2014-09-14"
Namespace(auth_host_name='localhost', auth_host_port=[8080, 8090], logging_level='ERROR', noauth_local_webserver=False, selected_date='2014-09-14')
usage: user_report.py [-h] [--auth_host_name AUTH_HOST_NAME]
[--noauth_local_webserver]
[--auth_host_port [AUTH_HOST_PORT [AUTH_HOST_PORT ...]]]
[--logging_level {DEBUG,INFO,WARNING,ERROR,CRITICAL}]
user_report.py: error: unrecognized arguments: -d 2014-09-14
看样子日期参数不被识别。任何帮助将非常感激!
你应该还包括用户钥的要求ARG? https://developers.google.com/resources/api-libraries/documentation/admin/reports_v1/python/latest/admin_reports_v1.userUsageReport.html 从pydocs看来,您需要的不仅仅是日期... – Emily 2014-09-30 23:22:46
我稍后在应用程序中将userKey添加为“全部”,这将为所有用户带回事件。当我没有试图传入外部参数时,该代码起作用。谢谢! – Alex 2014-10-01 14:15:04