不同进程共享变量

让不同进程共享变量,但又不想用什么管道方法实现,只想越简单越好,下面尝试了几种方法:
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

这样不同进程共享一个变量的想法就实现了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值