我用Python编写了一个脚本,然后在github上找到了另一个非常有用的脚本。我想自动化一个包含这两个脚本的更大的任务。我有一个批处理文件如下:
for /f "tokens=2 delims=:." %%x in ('chcp') do set cp=%%x
chcp 1252>nul
cd C:\python_projects\json_to_csv
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Bloc_Québécois.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Bloc_Québécois.json F:\electoral_map\%1\candidates\candidates_Bloc_Québécois.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Christian_Heritage.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Christian_Heritage.json F:\electoral_map\%1\candidates\candidates_Christian_Heritage.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Conservative.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Conservative.json F:\electoral_map\%1\candidates\candidates_Conservative.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Forces_et_Démocratie.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Forces_et_Démocratie.json F:\electoral_map\%1\candidates\candidates_Forces_et_Démocratie.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Green_Party.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Green_Party.json F:\electoral_map\%1\candidates\candidates_Green_Party.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Liberal.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Liberal.json F:\electoral_map\%1\candidates\candidates_Liberal.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_Libertarian.json
json2csv.py F:\electoral_map\%1\candidates\candidates_Libertarian.json F:\electoral_map\%1\candidates\candidates_Libertarian.outline.json
gen_outline.py --collection objects F:\electoral_map\%1\candidates\candidates_NDP.json
json2csv.py F:\electoral_map\%1\candidates\candidates_NDP.json F:\electoral_map\%1\candidates\candidates_NDP.outline.json
replace_first_line.py F:\electoral_map\%1\candidates\candidates_Conservative.csv F:\electoral_map\%1\candidates\candidates_Conservative_namefixed.csv
chcp %cp%>nul
pause我写了"replace_first_line.py“,另外两个脚本("gen_outline.py”和"json2csv.py")是从github取材的。
这是replace_first_line.py:
from sys import argv
def replace_first_line(fin_path, fout_path):
with open(fin_path) as fin:
lines = fin.readlines()
lines[0] = lines[0].replace('district_name,elected_office,election_name,email,extra_facebook,extra_instagram,extra_linkedin,extra_twitter,extra_youtube,first_name,gender,incumbent,last_name,name,offices_0_tel,offices_0_type,party_name,personal_url,photo_url,related_boundary_url,related_election_url,source_url,url',
'district_name,elected_office,election_name,email,extra_facebook,extra_instagram,extra_linkedin,extra_twitter,extra_youtube,first_name,gender,incumbent,last_name,name_,offices_0_tel,offices_0_type,party_name,personal_url,photo_url,related_boundary_url,related_election_url,source_url,url')
with open(fout_path, 'w') as fout:
for line in lines:
fout.write(line)
replace_first_line(argv[1], argv[2])当我在IDE中运行"replace_first_line.py“时,"argv1”可以正常工作,并将“argv1”替换为传递给批处理文件的相同参数。当我用该参数调用批处理文件时,它无法工作(我首先将它改为"argv1“)
其余的脚本都能工作,那么是什么原因呢?诚然,我的脚本是在Python3环境中编写的,但我认为里面没有任何东西是Python 2中没有的。
发布于 2015-09-15 22:53:13
底线:将文件名插入到文件名中。在python文件中,您要执行以下操作
replace_first_line(argv[1],argv[1].replace(".csv","namefixed.csv")与其他情况一样,如果将20150915传递给批处理文件,最终传递给replace_first_line的是F:\electoral_map\F:\electoral_map\20150915\candidates\candidates_Conservative.csv\candidates\candidates_Conservative.csv (注意两个f:\ etc)。
发布于 2015-09-15 22:24:55
Sending arguments from Batch file to Python script
看看这个,也许会有帮助。批处理文件和python脚本使用参数的方式不同,因此它可能与传递参数的方式有关。
https://stackoverflow.com/questions/32596629
复制相似问题