0

我正在编写一个小代码,它必须:

  • 与 SFTP 连接
  • 在 PostgreSQL 上执行命令(密码保护)

我愿意将密码用作纯文本。

目前我的代码是:

import pysftp

command = "... some SQL command"

sftp= pysftp.Connection('server_name', username='username', password='password')
sftp.execute("export PGPASSWORD='password_to_psql'")
sftp.execute("psql -h 127.0.0.1 -d {} -U {} -W -c "{}"").format(database_name, user_name, command)
sftp.close()

我认为这是个好主意,但是当我在终端中键入正确的命令时,shell 会提示输入密码(但不是必需的,当我“输入”时,一切都会执行。

有谁知道我如何“禁用”不需要的提示?

4

1 回答 1

1

psql有一个--no-password选项,也可以指定为-w.

看起来您可能拼错-w了 as -W,这会产生相反的效果。

于 2016-09-14T14:54:36.630 回答