第一。我已經想出了從標誌指定的命令行參數的方法。我粘貼低於使用修改「標記」的代碼和一個小模塊,展示瞭如何使用通過命令行收集到的參數代碼:
import argparse
parser = argparse.ArgumentParser()
#-db DATABASE -u USERNAME -p PASSWORD -size 20000
parser.add_argument("-host", "--hostname", dest = "hostname", default = "xyz.edu", help="Server name")
parser.add_argument("-db", "--database", dest = "db", default = "ding_dong", help="Database name")
parser.add_argument("-u", "--username",dest ="username", help="User name")
parser.add_argument("-p", "--password",dest = "password", help="Password")
parser.add_argument("-size", "--binsize",dest = "binsize", help="Size", type=int)
args = parser.parse_args()
print("Hostname {} db {} User {} Password {} size {} ".format(
args.hostname,
args.db,
args.username,
args.password,
args.binsize
))
def ConnectToDB():
print ('Trying to connect to mySQL server')
# Try to connect to the database
try:
con=sql.connect(host=args.hostname, user= args.username, passwd= args.password)
print ('\nConnected to Database\n')
# If we cannot connect to the database, send an error to the user and exit the program.
except sql.Error:
print ("Error %d: %s" % (sql.Error.args[0],sql.Error.args[1]))
sys.exit(1)
return con
我的一個關注的是如何使用的參數變量的代碼。對於這兩件事情需要完成
- 將'dest'添加到add_argument行e.x. dest =「username」,這意味着從comamnd行收集的值將被分配給變量'username'
- 每當您使用命令行分配的變量來自'dest'時,只需在變量前添加'args'ex con = sql.connect (主機= args.hostname,用戶= args.username,passwd文件= args.password)
完成
感謝
AK
http://docs.python.org/3/library/argparse.html獲取詳細信息 – Urhixidur 2016-05-05 16:59:05
您接受了您自己的問題解決方案,而** @ Mark **確實爲您提供了答案。我不確定這是否非常友善... – Atcold 2016-05-28 04:12:13