在Python中,你可以使用os
和subprocess
库来执行带有sudo权限的命令
import os
import subprocess
def run_command_with_sudo(command, group_name):
# 创建一个临时文件来存储sudo密码
sudo_password_file = "/tmp/sudo_password_{}".format(group_name)
# 将sudo密码写入临时文件
with open(sudo_password_file, "w") as f:
f.write("your_sudo_password_here")
# 设置文件权限,以便只有指定组可以读取密码
os.chmod(sudo_password_file, 0o600)
# 使用sudo执行命令,并将密码文件作为参数传递
try:
subprocess.run(["sudo", "-S", "-g", group_name] + command, check=True, stdin=open(sudo_password_file, "r"))
except subprocess.CalledProcessError as e:
print("Error executing command:", e)
finally:
# 删除临时文件
os.remove(sudo_password_file)
# 示例:使用sudo运行一个命令,仅限名为"sudoers"的组执行
command = ["ls", "-l"]
group_name = "sudoers"
run_command_with_sudo(command, group_name)
请注意,将密码写入文件并在命令执行后删除是一种不安全的方法。在实际应用中,你可能需要考虑更安全的方法,例如使用expect
库或配置/etc/sudoers
文件以允许特定用户无需密码执行特定命令。