Python 中的 sys.argv 是个什么鬼?
最近在 github 上 git 别人的代码下来学习 ,其中有一个 face-detection 相关的代码 ,就涉及了 sys.argv ,并且运行后是这个样子~
本着问问题前先百度先google的原则 ,在网上找到了原因 ,就出在sys.argv 上 。那么 ,它究竟是个什么鬼 ?
sys.argv[] 说白了就是一个从程序外部获取参数的桥梁 ,我们从外部取得的参数可以是多个 ,所以获得的是一个列表(list),也就是说sys.argv其实可以看作是一个列表 ,所以才能用[]提取其中的元素 。其第一个元素(sys.argv[0])是程序本身 ,随后才依次是外部给予的参数 。
下边用四句话来解释它到底是个什么鬼 !?
- 本质是一个列表
可以利用type()方法查看类型 :
import sys print(type(sys.argv)) print(len(sys.argv))
命令窗口调用得到的结果如下 ,证实为列表类型 。且外部输入元素用空格隔开
C:\Users\Jan\test2\tensorflow-face-detection>python test_argv.py 1 2 3 4 <class 'list'> 5
- 列表元素来自外部输入
- 外部输入从1开始
- argv[0] 表示本身代码文件路径
这里 ,创建一个test_argv.py 文件 ,在命令窗口调用并输入需要的参数 。
import sys script,first,second,third = sys.argv print ("The script is called:{%s}"% script) print ("The first variable is:{%s}"% first) print ("The second variable is:{%s}"% second) print ("The third variable is:{%s}"% third)
得到的结果如下:
C:\Users\Jan\test2\tensorflow-face-detection>python test_argv.py 1 2 3 The script is called:{test_argv.py} The first variable is:{1} The second variable is:{2} The third variable is:{3}
调用过程一共从外部输入3个参数 ,但是输出了四个 ,这个实例综合讲述了 2 ,3 ,4 三点 。即在外部输入时 ,argv[0] 默认为本身代码文件路径 ,且外部输入从 argv[1] 开始 。
对照着实例 ,其实还算比较好理解 。这里再举一个例子便于理解 。我们知道 os 模块里的 os.system 是可以打卡文件的,这里外部输入参数改为一个 txt 文件 ,调用sys.argv[] 打卡 。
import sys import os os.system(sys.argv[1])
在命令窗口调用并输入参数(参数为要打开的文件名),如下 。这里代码中参数为sys.argv[1],即外部输入的第一个参数test_argv.txt ,如果是sys.argv[0] ,则打开的是代码本身。
原文发布时间为:2018-07-08
本文作者:小詹同学
本文来自云栖社区合作伙伴“小詹学Python”,了解相关信息可以关注“小詹学Python”。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
开发一个自己的 CSS 框架(一)
这是一个系列,带着大家封装一个纯 CSS 框架,从零学习 SASS 语法。 代码仓库点我传送 因为简单,强依赖原生 Javascript 对虚拟 DOM 不友好(如 React、Vue、Angular),使用虚拟 DOM 对使用原生 Javascript 编程(JQuery)不友好。没有代码是最棒的代码,部署在任何地方,运行在任何地方。 我会告诉我叫 IE 吗? 看这表情,我会骗你? 抄刀开干 首先你得准备一个设计稿,什么?你没有? 首先得为 UI 选择一些基本色调,这其实是最核心的。当你改变一些基本配色之后,你会发现框架完全不同了。 搭建开发环境 初始化一个 Nodejs 项目,安装 parcel 打包工具,让 parcel 来帮我们处理可编译文件,使用简单,速度奇快,小微项目用 parcel 有如神助。 mkdir NicoUI && cd NicoUI npm init -y npm i parcel-bundler -D 创建开始文件 touch index.html index.sass 在 index.html 引入 index.sass 文件,我们使用 s...
- 下一篇
移动端跨平台开发的深度解析
跨平台一直是老生常谈的话题,cordova、ionic、react-native、weex、kotlin-native、flutter等跨平台框架的百花齐放,颇有一股推倒原生开发者的势头。(事实上更多是共存发展)看完本篇,相信你会对于当下跨平台移动开发的现状、实现原理、框架的选择等有更深入的理解。 一、前言 为什么我们需要跨平台开发? 本质上,跨平台开发是为了增加代码复用,减少开发者对多个平台差异适配的工作量,降低开发成本,提高业务专注的同时,提供比web更好的体验。嗯~通俗了说就是:省钱、偷懒。 本篇主要以react-native、weex、flutter,结合资讯展望,深入聊聊当前跨平台移动开发的实现原理、现状与未来。至于为什么只讲它们,因为对比ionic、phoneGap,它们更于 “naive” (˶‾᷄ ⁻̫ ‾᷅˵)。 二、原理与特性 目前移动端跨平台开发中,大致归纳为以下几种情况: react native、weex均使用JavaScript作为编程语言,目前JavaScript在跨平台开发中,可谓占据半壁江山,大有“一统天下”的趋势。kotlin-native开始支持 ...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Hadoop3单机部署,实现最简伪集群
- MySQL8.0.19开启GTID主从同步CentOS8
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果