使用命令行参数从Python运行C可执行文件

Running a C executable from Python with command line arguments(使用命令行参数从Python运行C可执行文件)
本文介绍了使用命令行参数从Python运行C可执行文件的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个C文件,名为myfile.c

现在要编译我正在做的事情:gcc myfile.c -o myfile

现在要运行此程序,我需要执行以下操作:./myfile inputFileName > outputFileName

其中inputFileNameoutputFileName是2个命令行输入。

现在我正尝试在一个python程序中执行此操作,我正在尝试下面的方法,但它不能正常工作可能是由于>

import subprocess
import sys

inputFileName = sys.argv[1];
outputFileName = sys.argv[2];

subprocess.run(['/home/dev/Desktop/myfile', inputFileName, outputFileName])

其中/home/dev/Desktop是我的目录的名称,myfile是可执行文件的名称。

我应该做什么?

推荐答案

您在命令中使用的>是output redirection的特定于外壳的语法。如果您希望通过Python执行相同的操作,则必须使用shell=True和单个命令行(而不是列表)调用外壳来为您执行此操作。

这样:

subprocess.run(f'/home/dev/Desktop/myfile "{inputFileName}" > "{outputFileName}"', shell=True)

如果您只想通过Python完成此操作而不调用外壳(这正是shell=True所做的),请查看另一个Q&;A:How to redirect output with subprocess in Python?

这篇关于使用命令行参数从Python运行C可执行文件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)