python子进程输出到列表或文件

beo*_*ver 6 python subprocess python-3.x

我想在Python 3中运行以下bash命令:

ls -l
Run Code Online (Sandbox Code Playgroud)

我知道我可以做以下事情:

from subprocess import call
call(['ls', '-l'])
Run Code Online (Sandbox Code Playgroud)

如何将此输出保存到文件中,或将其放入列表或集合中?

[-rw-r--r--]  [1] [name]  [staff]   [426] [14 Jan 21:52] [HelloWorld.class]
[-rw-r--r--@] [1] [name]  [staff]   [107] [14 Jan 21:51] [HelloWorld.java]
...
etc.
Run Code Online (Sandbox Code Playgroud)

我希望能够直接访问特定信息,然后将其添加到集合中,但我不知道将列出多少项目.

任何提示,片段或示例都会有所帮助.

Gar*_*rwe 22

使用python2.7,您可以使用subprocess.check_output:

ls_lines = subprocess.check_output(['ls', '-l']).splitlines()
Run Code Online (Sandbox Code Playgroud)

在python2.7之前,你需要使用较低级别的api,这需要更多一些.

ls_proc = subprocess.Popen(['ls', '-l'], stdout=subprocess.PIPE)
ls_proc.wait()
# check return code
ls_lines = ls_proc.stdout.readlines()
Run Code Online (Sandbox Code Playgroud)


jco*_*ado 11

访问ls -l输出中信息的一种方法是解析它.例如,csv.DictReader可以用于将每列映射到字典中的字段:

import subprocess
import csv

process = subprocess.Popen(['ls', '-l'], stdout=subprocess.PIPE)
stdout, stderr = process.communicate()

reader = csv.DictReader(stdout.decode('ascii').splitlines(),
                        delimiter=' ', skipinitialspace=True,
                        fieldnames=['permissions', 'links',
                                    'owner', 'group', 'size',
                                    'date', 'time', 'name'])

for row in reader:
    print(row)
Run Code Online (Sandbox Code Playgroud)

上面的代码将为输出中的每一行打印一个字典,ls -l例如:

{'group': '<group_name>',
 'name': '<filename>',
 'links': '1',
 'date': '<modified_date>',
 'time': '<modified_time>',
 'owner': '<user_name>',
 'permissions': '-rw-rw-r--',
 'size': '<size>'}
Run Code Online (Sandbox Code Playgroud)


Gar*_*rwe 7

如果您真正想要的是列出目录,而是使用os.listdir

import os
files = os.listdir('/path/to/dir')
for file in files:
    print(file)
Run Code Online (Sandbox Code Playgroud)