我在重新分配POSTCODE_VALID变量时遇到问题.当满足if条件时,它不会被重新分配.我确保满足if条件并且应该将其设置为true.但事实并非如此.有谁知道为什么?
POSTCODE_VALID=false find codepoint/ | while read i ; do if [[ $i =~ codepoint/$AREACODE ]] then #This is the variable that doesn't get re-assigned. POSTCODE_VALID=true fi done
chepner.. 6
管道创建子壳; 赋值POSTCODE_VALID
是该shell的本地,因此不会影响POSTCODE_VALID
父级.
更简单的解决方案是检查是否codepoint/$AREACODE
存在.
if [[ -f codepoint/$AREACODE ]]; then POSTCODE_VALID=true else POSTCODE_VALID=false fi
如果你确实需要进行更一般的匹配,请使用for循环并在匹配后立即中断:
POSTCODE_VALID=false for f in "codepoint/$AREACODE"*; do if [[ -f $f ]]; then POSTCODE_VALID=true break fi done
(基本上,这个循环最多只执行一次;如果没有匹配,则会按字面意思处理glob,当然,它不会是现有文件的名称.)
管道创建子壳; 赋值POSTCODE_VALID
是该shell的本地,因此不会影响POSTCODE_VALID
父级.
更简单的解决方案是检查是否codepoint/$AREACODE
存在.
if [[ -f codepoint/$AREACODE ]]; then POSTCODE_VALID=true else POSTCODE_VALID=false fi
如果你确实需要进行更一般的匹配,请使用for循环并在匹配后立即中断:
POSTCODE_VALID=false for f in "codepoint/$AREACODE"*; do if [[ -f $f ]]; then POSTCODE_VALID=true break fi done
(基本上,这个循环最多只执行一次;如果没有匹配,则会按字面意思处理glob,当然,它不会是现有文件的名称.)