我想使用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 位。