لقد حاولت زيادة متغير رقمي باستخدام كليهما var=$var+1
و var=($var+1)
دون نجاح. المتغير هو رقم ، على الرغم من باش يبدو أن قراءته كسلسلة.
باش الإصدار 4.2.45 (1)-الإصدار (س 86_64-بيسي-لينكس-غنو) على أوبونتو 13.10.
لقد حاولت زيادة متغير رقمي باستخدام كليهما var=$var+1
و var=($var+1)
دون نجاح. المتغير هو رقم ، على الرغم من باش يبدو أن قراءته كسلسلة.
باش الإصدار 4.2.45 (1)-الإصدار (س 86_64-بيسي-لينكس-غنو) على أوبونتو 13.10.
هناك أكثر من طريقة لزيادة متغير في باش ، ولكن ما حاولت غير صحيح.
يمكنك استخدام على سبيل المثال التوسع الحسابي:
var=$((var+1))((var=var+1))((var+=1))((var++))
أو يمكنك استخدام let
:
let "var=var+1"let "var+=1"let "var++"
انظر أيضا: http://tldp.org/LDP/abs/html/dblparens.html.
var=$((var + 1))
الحساب في استخدامات باش $((...))
بناء الجملة.
بفضل رد رادو رشيديانو التي توفر الطرق التالية لزيادة متغير في باش:
var=$((var+1))((var=var+1))((var+=1))((var++))let "var=var+1"let "var+=1" let "var++"
هناك طرق أخرى أيضا. على سبيل المثال ، ابحث في الإجابات الأخرى على هذا السؤال.
let var++var=$((var++))((++var)){ declare -i var var=var+1 var+=1}{ i=0 i=$(expr $i + 1)}
وجود الكثير من الخيارات يؤدي إلى هذين السؤالين:
#!/bin/bash# To focus exclusively on the performance of each type of increment# statement, we should exclude bash performing while loops from the# performance measure. So, let's time individual scripts that# increment $i in their own unique way.# Declare i as an integer for tests 12 and 13.echo > t12 'declare -i i; i=i+1'echo > t13 'declare -i i; i+=1'# Set i for test 14.echo > t14 'i=0; i=$(expr $i + 1)'x=100000while ((x--)); do echo >> t0 'i=$((i+1))' echo >> t1 'i=$((i++))' echo >> t2 '((i=i+1))' echo >> t3 '((i+=1))' echo >> t4 '((i++))' echo >> t5 '((++i))' echo >> t6 'let "i=i+1"' echo >> t7 'let "i+=1"' echo >> t8 'let "i++"' echo >> t9 'let i=i+1' echo >> t10 'let i+=1' echo >> t11 'let i++' echo >> t12 'i=i+1' echo >> t13 'i+=1' echo >> t14 'i=$(expr $i + 1)'donefor script in t0 t1 t2 t3 t4 t5 t6 t7 t8 t9 t10 t11 t12 t13 t14; do line1="$(head -1 "$script")" printf "%-24s" "$line1" { time bash "$script"; } |& grep user # Since stderr is being piped to grep above, this will confirm # there are no errors from running the command: eval "$line1" rm "$script"done
i=$((i+1)) user 0m0.992si=$((i++)) user 0m0.964s((i=i+1)) user 0m0.760s((i+=1)) user 0m0.700s((i++)) user 0m0.644s((++i)) user 0m0.556slet "i=i+1" user 0m1.116slet "i+=1" user 0m1.100slet "i++" user 0m1.008slet i=i+1 user 0m0.952slet i+=1 user 0m1.040slet i++ user 0m0.820sdeclare -i i; i=i+1 user 0m0.528sdeclare -i i; i+=1 user 0m0.492si=0; i=$(expr $i + 1) user 0m5.464s
يبدو باش هو الأسرع في أداء i+=1
عندما $i
يتم الإعلان عن عدد صحيح. let
تبدو البيانات بطيئة بشكل خاص ، و expr
هو إلى حد بعيد أبطأ لأنها ليست في صلب باش.
هناك أيضا هذا:
var=`expr $var + 1`
تأخذ علما حذرا من المساحات وأيضا ` ليس '
في حين إجابات رادو ، والتعليقات ، هي شاملة ومفيدة للغاية ، فهي باش محددة. وأنا أعلم أنك لم تسأل على وجه التحديد عن باش ، ولكن اعتقدت أنني سوف الأنابيب في منذ وجدت هذا السؤال عندما كنت أبحث أن تفعل الشيء نفسه باستخدام ش في بوسيبوكس تحت أوكلينوكس. هذا المحمولة وراء باش.
إذا كنت تعلن $var
كعدد صحيح، ثم ما حاولت في المرة الأولى سوف تعمل في الواقع:
$ declare -i var=5$ echo $var5$ var=$var+1$ echo $var6
هناك طريقة واحدة مفقودة في جميع الإجابات - bc
$ VAR=7 $ bc <<< "$VAR+2"9$ echo $VAR7$ VAR=$( bc <<< "$VAR+1" )$ echo $VAR8
bc
يتم تحديده بواسطة بوسيكس القياسية ، لذلك يجب أن تكون موجودة على جميع إصدارات أوبونتو والأنظمة المتوافقة مع بوسيكس. ال <<<
يمكن تغيير إعادة التوجيه إلى echo "$VAR" | bc
لقابلية النقل ، ولكن بما أن السؤال يسأل عن bash
- لا بأس أن تستخدم فقط <<<
.
رمز الإرجاع 1
المشكلة موجودة لجميع المتغيرات الافتراضية (let
, (())
، إلخ.). هذا غالبا ما يسبب المتاعب ، على سبيل المثال ، في البرامج النصية التي تستخدم set -o errexit
. هنا هو ما أستخدمه لمنع رمز الخطأ 1
من التعبيرات الرياضية التي تقيم إلى 0
;
math() { (( "$@" )) || true; }math a = 10, b = 10math a++, b+=2math c = a + bmath mod = c % 20echo $a $b $c $mod#11 12 23 3
هذا يجب أن يكون أسوأ طريقة لإنجاز مثل هذه المهمة البسيطة ولكن أردت فقط لتوثيق ذلك للمتعة أعتقد (العكس تماما من كود جولف).
$ var=0$ echo $var0$ var="$(python -c 'print('$var'+1)')"$ echo $var1
أو
$ var="$(printf '%s\n' $var'+1' | bc)"$ echo $var1
استخدم بجدية أحد الخيارات الأخرى الأفضل هنا.
هذا هو الرهان الآمن
(( var = var + 1 ))
إذا كانت القيمة الناتجة غير صفرية، فإن تعيين الخروج عند الخطأ سيوقف البرنامج النصي الخاص بك
set -evar=0(( var++ ))echo You will never get here