首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从python脚本运行imposm命令

从python脚本运行imposm命令
EN

Stack Overflow用户
提问于 2016-01-10 11:26:21
回答 2查看 177关注 0票数 1

我刚刚开始使用imposm来帮助将openstreetmap数据导入postgis数据库。所有的文档都指向通过终端执行所有命令。这对于一次性导入是很好的,但我计划有许多不同边界框的导入,并希望在数据库中加载数据的脚本。

目前我使用的是:

代码语言:javascript
复制
imposm --overwrite-cache --read --write -d postgis_test --user postgres -p ""  /Users/Me/MapnikTest/osmXML.osm

它从命令行运行得很好,但是由于osmXML.osm被创建了很多次,所以我想在创建的时候导入它。

在python脚本中放置相同的内容,如下所示:

代码语言:javascript
复制
os.system("imposm --overwrite-cache --read --write -d postgis_test --user postgres -p ""  /Users/Ali\ Mac\ Pro/Desktop/MapnikTest/osmXML.osm")

只返回:

代码语言:javascript
复制
/bin/sh: imposm: command not found

解决这个问题将是自动获取数据以按需渲染小地图的最后一步,但我遇到了最后一个障碍!

** Edit full path to imposm解决了第一个问题,但在提示时输入postgres用户的密码。有没有办法在同一行命令中发送密码?(也许这需要一个新的帖子?,如果有人给我指明了正确的方向,我很高兴)**

EN

回答 2

Stack Overflow用户

发布于 2016-01-10 13:49:48

这可能是因为os.system()调用了/bin/sh,它使用了与您在命令行上工作时使用的不同的shell环境。

要解决此问题,请在脚本中获取imposm脚本的完整路径,然后在命令中使用该路径。使用可以使用some code like this查找可执行文件。

或者,您可以修复您的PATH定义,以便/bin/sh具有正确定义的shell,但这在很大程度上取决于您的设置……

票数 0
EN

Stack Overflow用户

发布于 2016-01-11 01:35:00

在进一步的研究和@Eli Rose的评论的帮助下得到了解决(非常感谢):找出使用imposm的路径(或您正在尝试执行的任何命令)

代码语言:javascript
复制
which <command>

然后将路径包含在python shell命令中。使用子进程中的模块,您甚至可以看到完整的终端输出。

代码语言:javascript
复制
import subprocess
from subprocess import *
print Popen("/usr/local/bin/imposm --overwrite-cache --read --write --connection postgis://<database user>:<password>@<host>/<database> /path/to/data.osm", stdout=PIPE, shell=True).stdout.read()

这个

代码语言:javascript
复制
--connection postgis://<database user>:<password>@<host>/<database>

这意味着您可以在一行中执行该命令,而不必担心在下面的命令中输入数据库用户密码。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34701730

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档