在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
文件以允许特定用户无需密码执行特定命令。