- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在将命令行参数传递给脚本,比如 a.sh。
在 a.sh 中,我使用“$@”将所有这些参数传递给另一个 bash 脚本 (user_pref.sh)。在这个 bash 文件中,我试图根据使用基本 if 条件从 a.sh 收到的参数分配 0 或 1。但出于某种原因,我无法推断出正确的值,并且我的所有变量都设置为 0。我是 bash 脚本的新手,非常感谢这里的任何帮助。我在网站上提到了不同的帖子,但到目前为止它们没有帮助我解决我的问题。
a.sh代码
#!/bin/bash
/home/postgres/viraltest_scripts/user_pref.sh "$@" &> /home/postgres/viraltest_scripts/logs/refresh_dev_sql.log
user_pref.sh代码:
#!/bin/bash
## assigning default values
a=1
b=1
c=1
if [[ $1 -eq 0 ]]
then
a=0
fi
if [[ $2 -eq 0 ]]
then
b=0
fi
if [[ $3 -eq 0 ]]
then
c=0
fi
无论我从 a.sh 传递什么,user_pref.sh 中的所有变量都被分配为 0。任何人都可以指出我在 If 语句中做错了什么吗?PS:我知道分配 a=$1 但出于我的应用程序的目的,我必须明确分配 0 或 1 而不是执行 a=$1。
最佳答案
编辑 您文件的第一行应该是#!/bin/bash
,而不是#!/bin/sh
。您正在使用 bash 扩展,因此请确保您要求脚本由 bash(而不是 sh、dash、csh 等)解释。
其次,-eq
测试numeric 相等性,而不是string 相等性。结果,[[ '' -eq 0 ]]
为真。我认为您可能需要 [[ $# -ge 1 && $1 = 0 ]]
以及类似的测试。 $# -ge 1
检查是否实际提供了参数,然后 =
测试字符串是否相等。像这样:
a=1
if [[ $# -ge 1 && $1 = 0 ]]; then a=0 ; fi
b=1
if [[ $# -ge 2 && $2 = 0 ]]; then b=0 ; fi
c=1
if [[ $# -ge 3 && $3 = 0 ]]; then c=0 ; fi
编辑 2 不确定这是否满足您的要求,但由于您只传递 0
或 1
,您可以使用默认分配:
a="${1:-1}"
b="${2:-1}"
c="${3:-1}"
"${foo:-def}"
是具有默认值的替换。如果 $foo
未设置或为 null,则结果为 def
;否则,$foo
就是结果。
根据 OP 的评论:
$ cat a.sh
#!/bin/bash
./user_pref.sh "$@"
$ cat user_pref.sh
#!/bin/bash
set -x
a=1
if [[ $# -ge 1 && $1 = 0 ]]; then a=0 ; fi
b=1
if [[ $# -ge 2 && $2 = 0 ]]; then b=0 ; fi
c=1
if [[ $# -ge 3 && $3 = 0 ]]; then c=0 ; fi
echo a-"$a"- b-"$b"- c-"$c"
$ ./a.sh
+ a=1
+ [[ 0 -ge 1 ]]
+ b=1
+ [[ 0 -ge 2 ]]
+ c=1
+ [[ 0 -ge 3 ]]
+ echo a-1- b-1- c-1
a-1- b-1- c-1
手动给它 1
的情况(即使 1
是默认值):
$ ./a.sh 1
+ a=1
+ [[ 1 -ge 1 ]] <--- it saw the parameter
+ [[ 1 = 0 ]]
+ b=1
+ [[ 1 -ge 2 ]]
+ c=1
+ [[ 1 -ge 3 ]]
+ echo a-1- b-1- c-1
a-1- b-1- c-1
我认为 OP 指的是:
$ ./a.sh 0
+ a=1
+ [[ 1 -ge 1 ]] <--- it saw the parameter...
+ [[ 0 = 0 ]]
+ a=0 <--- ...and it overrode the default.
+ b=1
+ [[ 1 -ge 2 ]]
+ c=1
+ [[ 1 -ge 3 ]]
+ echo a-0- b-1- c-1
a-0- b-1- c-1
$ ./a.sh 0 0 0
+ a=1
+ [[ 3 -ge 1 ]]
+ [[ 0 = 0 ]]
+ a=0
+ b=1
+ [[ 3 -ge 2 ]]
+ [[ 0 = 0 ]]
+ b=0
+ c=1
+ [[ 3 -ge 3 ]]
+ [[ 0 = 0 ]]
+ c=0
+ echo a-0- b-0- c-0
a-0- b-0- c-0
关于linux - bash 脚本 : if condition,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46978494/
现在我已经创建了一个额外的跨度来容纳一个条件。 568 || subKey == 0" ng-repeat="links in linksWrap.links">
一些 excel IF 语句可能会变得相当长,我正在寻找一种更简单的方法来编写它们。例如,如果我要写: If($B$4+13=7,$B$4+13,FALSE) 我认为它会更容易说: If($B$4+1
我有一个包含 FromDate 、 ToDate 、 VendorName 和 GoodsName 的表单,一旦一切为真,我需要显示结果 示例: FromDate="11/20/2019"、ToDat
我经常看到使用 !!condition 而不仅仅是常规条件的代码。即: if(!!value){ doSomething(); } 对比: if(value){ doSomething
这个问题有点模棱两可,这两个在汇编代码/性能方面是否等效: public void example{ do{ //some statements; if(condition)
在我看到的使用 Any 方法的 Linq 查询示例中,大约有一半是通过将其应用于 Where() 调用的结果来实现的,另一半则直接将其应用于集合。这两种样式是否总是等效的,或者在某些情况下它们可能会返
这个问题在这里已经有了答案: What does !!(x) mean in C (esp. the Linux kernel)? (3 个答案) 关闭 9 年前。 我见过人们使用带有两个 '!'
我对部署在生产环境中的应用程序进行了线程转储,该应用程序使用 logback。我不是分析线程转储的专家,但是,我必须这样做。正在学习,网上也看了一些文章。 下面是真正的线程转储: "logback-8
在 SQL 中(特别是 Postgres): 子句 where not foo='bar' in case foo is null 评估为某种 null,导致该行不是包含在结果中。 另一方面,子句 w
是不是类似于has and condition with join和where condition after join? 例如 对于以下两个查询,它会给我相同的结果吗 1) SELECT COUNT
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
如果您调用某个函数,并且该函数在发生错误时返回 NULL(例如,想想 malloc() 或 fopen()),两个更好: FILE *fp = fopen(argv[0], "r"); if (fp
我正在使用 Azure 数据工厂 V2,我需要在父检查验证中实现两级检查。例如:如果条件一为真,那么我需要检查条件 2。并且,如果条件 2 为真,则检查条件 3。 这是一种分层检查。当我在父 IF 条
使用 Linq to Entities 有以下区别吗? db.EntityName.Where(a => a.Id == id).FirstOrDefault(); db.EntityName.Fir
我有一种情况,我已经用两种不同的方式解决了,但想知道人们对这些选项的看法,以及他们是否有其他选择...... 系统正在处理数据的“间隔”。 所有数据都分配到一个“区间” 该间隔由事实表 中的“inte
我有包含字段 Amount, Condition1, Condition2 的表格。 例子: Amount Condition1 Condition2 ---------------------
我正在尝试在 Netbeans 中制作一个简单的 MySQL、Java JDBC Web 应用程序。我希望根据当前 session 中的状态变量显示不同的内容。我尝试了以下方法: 首先,我在 .jsp
我想为 postnuke cms 设计一个主题。 并希望在模板文件中使用 css 条件。 postnuke 使用类似 smarty 的标签 .... 所以当我使用 .... 它给出了一些关于标签的错误
我想问一下asyncio.Condition .我对这个概念并不熟悉,但我从学生时代就知道并了解锁、信号量和队列。 我找不到很好的解释或典型的用例,只是 this example .我看了看来源。核心
我想知道如何在不在语句中重做相同查询两次的情况下处理 SQL 比较。这是我要找的: SELECT columnName10, IF( SELECT columnName20 FROM Othe
我是一名优秀的程序员,十分优秀!