python脚本传参

  • sys.argv
  • argparse

 第一种:argparse

简单使用:

import argparse # 创建一个参数解析实例
parser = argparse.ArgumentParser(description='Parameters') # 添加参数解析
parser.add_argument('--training_epoch', type=int, default=3000)
parser.add_argument('--learning_rate', type=float, default=0.001)
parser.add_argument('--model_name', type=str, default='lstm')# 开始解析args = parser.parse_args(args=[]) # 输出参数
print({args})
print(args.training_epoch)
print(args.learning_rate)
print(args.model_name)

parser.add_argument('--go', help='input file path')

name or flags:
普通参数或flag参数选项参数的名称或标签,例如 epochs 或者 -e, --epochs。Flag参数不需要指定参数值,只需要带有参数名即可。
action: 命令行遇到flags参数时的动作。有两个常见的动作,store_true:设定flag参数为true;-store_false:设定flag参数为False。注意:如果直接运行程序,默认不读取该变量,要使用必须要进行传参,例如:python try.py --epochs
nargs: 应该读取的命令行参数个数,可以是具体的数字,或者是?号,当不指定值时对于 Positional argument 使用 default,对于 Optional argument 使用 const;或者是 * 号,表示 0 或多个参数;或者是 + 号表示 1 或多个参数。
default: 不指定参数时该参数的默认值。
type: 命令行参数应该被转换成的数据类型。
required: 是否为必选参数或可选参数。
help: 参数的帮助信息。
metavar: 在 usage 说明中的参数名称,对于必选参数,默认就是参数名称,对于可选参数默认是全大写的参数名称。
dest: 解析后的参数名称,默认情况下,对于可选参数选取最长的名称,中划线转换为下划线.
choices: 参数可允许的值的一个容器。
const: action 和 nargs 所需要的常量值。
store_const:表示赋值为const;
append:将遇到的值存储成列表,也就是如果参数重复则会保存多个值;
append_const:将参数规范中定义的一个值保存到一个列表;
count:存储遇到的次数;此外,也可以继承 argparse.Action 自定义参数解析;
 

可以给KerasReadModel.py直接控制台传参数:

import argparse
parser = argparse.ArgumentParser()
## nargs='+'接受1个或多个参数,
## nargs='*'接受零个或多个
parser.add_argument('--list', nargs='+', help='<Required> Set flag', required=True)
args = parser.parse_args()if __name__ == '__main__':print(args.list)

运行结果如下:

 

import argparse
parser = argparse.ArgumentParser()
parser.add_argument('--ll', action='append', help='<Required> Set flag', required=True)
args = parser.parse_args()if __name__ == '__main__':print(args.ll)

 运行示例及结果:

亲测:讲文件KerasReadModel.py进行打包KerasReadModel.exe,然后控制台传入参数

import tensorflow as tf
from sklearn.preprocessing import StandardScaler
import argparse
import numpy as npdef readModel():parser = argparse.ArgumentParser()parser.add_argument('--test_data', type=float, nargs='+', required=True)args = parser.parse_args()test_array = np.array(args.test_data)  # 将传入的list转为array类型print('test_array:',test_array)ne_test_array=test_array.reshape(1,7).tolist()print('ne_test_array:', ne_test_array)# data_x = [[1, 80, 170, 50, 370, 79.3, 0]]sc = StandardScaler()x_data = sc.fit_transform(ne_test_array)new_model = tf.keras.models.load_model('./saved_model/blood_model', compile=False,custom_objects={"TrajGRUCell": 'TrajGRUCell', "TrajGRU": 'TrajGRU'})y_pred = new_model.predict(x_data)print(y_pred)if __name__ == "__main__":readModel()

 注意reshape用法记录一下:

# numpy中reshape函数的三种常见相关用法
#
# reshape(1,-1)转化成1行:
#
# reshape(2,-1)转换成两行:
#
# reshape(-1,1)转换成1列:
#
# reshape(-1,2)转化成两列
# 如果一个 ndarray 有 个元素,那么它的 reshape(-1, 1, 2) 方法将返回一个 shape = (n, 1, 2) 的 ndarray.

打包文件和模型放到一起:

 

控制台执行命令:

E:\开发工具\pythonProject\flaskTest\dist>KerasReadModel.exe --test_data 0 80 170 50 370 79 0
 

 

成功!

 第二种:sys.args

实际测试,传递列表

def readModel():test_data=sys.argv[1:]print('test_data:', test_data)test_array = np.array(test_data)  # 将传入的list转为array类型print('test_array:',test_array)ne_test_array=test_array.reshape(1,7).tolist()# data_x = [[1, 80, 170, 50, 370, 79.3, 0]]sc = StandardScaler()x_data = sc.fit_transform(ne_test_array)new_model = tf.keras.models.load_model('./saved_model/blood_model', compile=False,custom_objects={"TrajGRUCell": 'TrajGRUCell', "TrajGRU": 'TrajGRU'})y_pred = new_model.predict(x_data)print(y_pred)if __name__ == "__main__":readModel()
(venv) E:\开发工具\pythonProject\flaskTest>KerasReadModel.py 1 80 170 50 370 79.3 0

 

详细用法来自网上:

一、sys.argv[0]
sys.argv[0] 用来获取执行的脚本名称。 

# test.py
import sysdef receive_args():file_name = sys.argv[0]print file_namereceive_args()执行结果:
#python test.py 
test.py

二、sys.argv[:]
sys.argv[:]用来获取参数列表,注意sys.argv[1:]这样可以去掉脚本名称

import sysdef receive_args():file_name = sys.argv[0]all_args = sys.argv[:]print file_nameprint all_argsreceive_args()#python test.py "2023-03-14" "liming" "shopping"
test.py
['test.py', '2023-03-14', 'liming', 'shopping']

 三、sys.argv[n]
n 代表数字1,2,3… 表示第几个参数,用来获取指定参数

import sysdef receive_args():file_name = sys.argv[0]all_args = sys.argv[:]time = sys.argv[1]who = sys.argv[2]do_what = sys.argv[3]print file_nameprint all_argsprint timeprint whoprint do_whatreceive_args()#python test.py "2023-03-14" "liming" "shopping"
test.py
['test.py', '2023-03-14', 'liming', 'shopping']
2023-03-14
liming
shopping

 四、利用列表其他属性
下面仅使用append()方法

import sysdef receive_args():file_name = sys.argv[0]all_args = sys.argv[:]time = sys.argv[1]who = sys.argv[2]do_what = sys.argv[3]print file_nameprint all_argsprint timeprint whoprint do_whatall_args.append("morning")print all_argsreceive_args()#python test.py "2023-03-14" "liming" "shopping"
test.py
['test.py', '2023-03-14', 'liming', 'shopping']
2023-03-14
liming
shopping
['test.py', '2023-03-14', 'liming', 'shopping', 'morning']

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/293448.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Python计算二维截面的惯性矩和面积,中间带洞的截面也可计算,代码

因为最近到土木行业了&#xff0c;所以要计算二维截面的惯性矩和面积&#xff0c;用迈达斯太low了&#xff0c;所以想自己写python代码计算。前言 主要思路是三角网划分&#xff0c;然后计算每个小三角的惯性矩和面积&#xff0c;求和得到最终截面的惯性矩和面积。 python中可…

Ubuntu 常用命令之 chown 命令用法介绍

&#x1f4d1;Linux/Ubuntu 常用命令归类整理 chown 命令在 Ubuntu 系统中用于改变文件或目录的所有者和组。这个命令的基本格式是 chown [选项]... [所有者][:[组]] 文件...。 chown 命令的主要参数有 -c 或 --changes&#xff1a;类似 verbose&#xff0c;但只在发生改变时…

解决xcode 运行不老iPhone 15 iOS 17.1 设备的问题

问题 最近要查看一下ios 17.1的设备的性能&#xff0c;但是当前版本的Xcode运行不了 解决方法 1、更新Xcode版本到15.1以上 2、更新完成后&#xff0c;大概率出现这个情况 原因&#xff1a;在app Store中更新到Xcode15后,运行不了模拟器和真机.需要下载iOS 17对应的模拟器.&…

Linux基本内容学习

Linux 命令 文件命令 命令释义语法格式lslist&#xff0c;用于显示目录中文件及其属性信息ls [参数名] [文件名]cdchange directory&#xff0c;用于更改当前所处的工作目录&#xff0c;路径可以是绝对路径&#xff0c;也可以是相对路径&#xff0c;若省略不写则会跳转至当前…

前端案例—antdDesign的Select多选框组件加上全选功能

前端案例—antdDesign的Select多选框组件加上全选功能。 实现效果如下&#xff1a; Select 组件里有这个属性&#xff0c;可以利用这个对下拉菜单进行自定义。 const handleChange (e, value) > {setSelectState(e.target.checked)let arr productOptions?productOption…

HarmonyOS应用事件打点开发指导

简介 传统的日志系统里汇聚了整个设备上所有程序运行的过程流水日志&#xff0c;难以识别其中的关键信息。因此&#xff0c;应用开发者需要一种数据打点机制&#xff0c;用来评估如访问数、日活、用户操作习惯以及影响用户使用的关键因素等关键信息。 HiAppEvent 是在系统层面…

【JavaWeb学习笔记】14 - 三大组件其二 Listener Filter

API文档JAVA_EE_api_中英文对照版 Listener 一、监听器Listener 1. Listener监听器它是JavaWeb的三大组件之一。 JavaWeb的三大组件分别是: Servlet程序、Listener监听器、Filter过滤器 2. Listener是JavaEE的规范&#xff0c;就是接口 3.监听器的作用是&#xff0c;监听某…

稳定币分析的 3 个关键指标

作者&#xff1a;lesleyfootprint.network 数据源&#xff1a;The Stablecoin Dashboard 稳定币因其固有特性而在加密货币领域中独树一帜&#xff0c;它们的特点是价格与特定的参考资产&#xff08;通常是美元或欧元等法定货币&#xff09;锚定。这种锚定机制的目的是缓解数字…

Pytorch常用的函数(五)np.meshgrid()和torch.meshgrid()函数解析

Pytorch常用的函数(五)np.meshgrid()和torch.meshgrid()函数解析 我们知道torch.meshgrid()函数的功能是生成网格&#xff0c;可以用于生成坐标&#xff1b; 在numpy中也有一样的函数np.meshgrid()&#xff0c;但是用法不太一样&#xff0c;我们直接上代码进行解释。 1、两者…

nuxt3快速上手

1.安装&#xff1a; npx nuxi init project-name # project-name 是项目名,如果下载不下来请挂梯子。2.安装依赖&#xff1a; npm install3.运行项目&#xff1a; npm run dev4.代码解释&#xff1a; <template><!-- app.vue 是所有页面的入口&#xff1a; --&g…

力扣题目学习笔记(OC + Swift)19. 删除链表的倒数第 N 个结点

19. 删除链表的倒数第 N 个结点 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 此题目为链表题&#xff0c;拿出我们的杀手锏&#xff0c;链表解题经典三把斧&#xff1a; 哑巴节点栈快慢指针 关于内存问题&#xff1a;由于Swift及…

选择移动订货系统源码的四大原因

移动订货系统需要选择源码支持的厂家&#xff0c;有以下四个原因&#xff0c;其中第四个是比较重要的&#xff0c;大家点个关注点个赞&#xff0c;我们接着往下看。 1.可自行定制&#xff1a;支持源码的移动订货系统可以根据企业的具体需求进行定制开发&#xff0c;满足企业特定…