Python子进程不传输参数

时间:2017-11-03 13:49:27

标签: java python subprocess osmosis

我希望使用osmosis自动执行从大型OSM文件中提取数据的过程,但是我在运行此代码段时遇到问题,以便从OSM数据自动创建磁贴:

import sys
import subprocess

def create_tile_pbf(pbf_file, tile_lng, tile_lat):
    """Runs the osmosis tile creator"""
    app_path = "osmosis/bin/"
    app = "osmosis.bat"
    proc = subprocess.Popen([
        app_path + app,
        "--read-pbf", pbf_file,
        "--bounding-box",
        "top=%d" % (tile_lat+1),
        "left=%d" % (tile_lng),
        "bottom=%d" % (tile_lat),
        "right=%d" % (tile_lng+1),
        "--write-pbf", "someotherfile.osm.pbf"
        ], cwd=app_path, shell=True)
    # Poll the proc to see if it is finished
    while proc.returncode is None:
        proc.communicate()
        proc.poll()
    print(">> Terminated\n")

if __name__ == "__main__":
    print("Args were: " + str(sys.argv) + "\n")
    create_tile_pbf("./somefile.osm.pbf", 7, 46)

我尝试使用和不使用shell=True,我尝试将所有参数加入到单个字符串中。但是在执行它时我总是遇到这个错误:

Nov 03, 2017 2:26:28 PM org.openstreetmap.osmosis.core.Osmosis main
SEVERE: Execution aborted.
org.openstreetmap.osmosis.core.OsmosisRuntimeException: Expected argument 1 to be an option or task name.
        at org.openstreetmap.osmosis.core.cli.CommandLineParser.parse(CommandLineParser.java:79)
        at org.openstreetmap.osmosis.core.Osmosis.run(Osmosis.java:74)
        at org.openstreetmap.osmosis.core.Osmosis.main(Osmosis.java:37)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
        at java.lang.reflect.Method.invoke(Unknown Source)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launchStandard(Launcher.java:330)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:238)
        at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
        at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
        at org.codehaus.classworlds.Launcher.main(Launcher.java:47)

但是当使用Powershell或命令提示符运行命令时,它就像魅力一样。

.\osmosis.bat --read-pbf .\somefile.osm.pbf --bounding-box top=47 left=7 bottom=46 right=8 --write-pbf someotherfile.osm.pbf

我使用Anaconda 4.3.30运行Windows 10 1703 64位。

1 个答案:

答案 0 :(得分:2)

脚本与命令提示符互动之间的差异为osmosis/bin/osmosis.bat.\osmosis.bat。由于您对Popen()的调用已包含cwd选项,因此您无需再次指定目录。这意味着你的电话应该是:

proc = subprocess.Popen([
    app,                                    # <== No app_path here
    "--read-pbf", pbf_file,
    "--bounding-box",
    "top=%d" % (tile_lat+1),
    "left=%d" % (tile_lng),
    "bottom=%d" % (tile_lat),
    "right=%d" % (tile_lng+1),
    "--write-pbf", "someotherfile.osm.pbf"
    ], cwd=app_path, shell=True)           # <== because of this cwd