让不同进程共享变量,但又不想用什么管道方法实现,只想越简单越好,下面尝试了几种方法:
1.用的是全局变量概念,后来才发现不同进程中的全局变量并不共享,失败告终
2.在网上看了一圈,发现还有模块化变量这个概念,和全局变量思想思想,不同进程共享失败
3.尝试了类成员变量,失败
4.用命令行参数尝试成功
实例代码如下:
command = f'python {file_name} --global_datas_path {self.global_datas_path} --global_weights_path {self.global_weights_path}'
subprocess.run(command, shell=True)
- python: 启动 Python 解释器。
- file_name: 要运行的 Python 脚本的文件路径。
- –global_datas_path 和 --global_weights_path: 用于传递参数给脚本的命令行参数。
- self.global_datas_path 和 self.global_weights_path: 包含实际参数值的类成员变量。
- subprocess.run(command, shell=True) 是用于在 Python 中执行外部命令或程序的方法。command
是命令字符串,shell=True 表示将命令作为 shell 命令运行。
脚本文件中变量接收形式如下
parser = argparse.ArgumentParser(description='path')
# 添加多个命令行参数,每个参数对应一个值
parser.add_argument('--global_datas_path', type=str, help='datas_path')
parser.add_argument('--global_weights_path', type=str, help='weights_path')
# 解析命令行参数
args = parser.parse_args()
# 获取命令行参数中的变量值
datas_path= args.global_datas_path
weights_path = args.global_weights_path
这样不同进程共享一个变量的想法就实现了