在python中完成for循环后调用子进程
我有如下的python脚本。在这个脚本中,我将脚本的stdout和stderr收集到一个文件中,并存储在Linux中 在这个脚本中,我在输入文件上的循环中运行函数path\u finder 在这个脚本中,我使用subprocess将Linux中的数据移动到不同的位置 我希望此子流程调用在完成循环后运行,但它在循环第一次运行时运行,在循环第二次运行时抛出预期的错误。当文件存在时,它会抛出一个错误在python中完成for循环后调用子进程,python,for-loop,subprocess,Python,For Loop,Subprocess,我有如下的python脚本。在这个脚本中,我将脚本的stdout和stderr收集到一个文件中,并存储在Linux中 在这个脚本中,我在输入文件上的循环中运行函数path\u finder 在这个脚本中,我使用subprocess将Linux中的数据移动到不同的位置 我希望此子流程调用在完成循环后运行,但它在循环第一次运行时运行,在循环第二次运行时抛出预期的错误。当文件存在时,它会抛出一个错误 #!/usr/bin/python import os import sys import trac
#!/usr/bin/python
import os
import sys
import traceback
import subprocess
def path_finder(
table,
mysql_user,
user,
dir,
):
day = datetime.now().strftime('%Y-%m-%d')
month = datetime.now().strftime('%Y-%m')
Linux_path = '/data/logging/{}'.format(input_file)
New_path = '/user/{}/{}/logging/{}/{}/{}'.format(user,dir,mysql_user,month,day)
subprocess.call(["rm", Linux_path])
so = se = open('/data/logging/{}'.format(input_file), 'a',
0)
#re-open stdout without buffering
sys.stdout = os.fdopen(sys.stdout.fileno(), 'a', 0)
# redirect stdout and stderr to the log file opened above
os.dup2(so.fileno(), sys.stdout.fileno())
os.dup2(se.fileno(), sys.stderr.fileno())
### CODE:
Do something
### if errors the print traceback
### repeat the same for every table in input file
## Execute below statement after for loop completed
subprocess.call(["cp", Linux_path, New_path])
if len(sys.argv) != 5:
print 'Invalid number of args......'
exit()
input_file = sys.argv[1]
mysql_user = sys.argv[2]
user = sys.argv[3]
dir = sys.argv[4]
input = open("{}.format(input_file)", "r")
for table in input:
path_finder(
table,
mysql_user,
user,
dir,
)
sc.stop()
print
如何更改脚本,使子进程调用在for循环完成后运行?我不知道问题出在哪里。您希望最后执行的语句当前存在于函数“path_finder”中,这就是它每次运行的原因。 要使此操作只在for循环完成后运行一次,请将语句放在它后面
for table in input:
path_finder(
table,
mysql_user,
user,
dir,
)
subprocess.call(["cp", Linux_path, New_path])
这应该可以做到