PHP में, स्ट्रिंग्स को एक साथ इस प्रकार संकलित किया जाता है:
$foo = "Hello";
$foo .= " World";
यहाँ, $foo
"हैलो वर्ल्ड" बन जाता है।
यह बैश में कैसे पूरा किया जाता है?
foo1="World" foo2="Hello" foo3="$foo1$foo2"
PHP में, स्ट्रिंग्स को एक साथ इस प्रकार संकलित किया जाता है:
$foo = "Hello";
$foo .= " World";
यहाँ, $foo
"हैलो वर्ल्ड" बन जाता है।
यह बैश में कैसे पूरा किया जाता है?
foo1="World" foo2="Hello" foo3="$foo1$foo2"
जवाबों:
foo="Hello"
foo="${foo} World"
echo "${foo}"
> Hello World
सामान्य तौर पर दो चर को समाप्त करने के लिए आप उन्हें एक के बाद एक लिख सकते हैं:
a='Hello'
b='World'
c="${a} ${b}"
echo "${c}"
> Hello World
$foo
डबल कोट्स के अंदर डालने की आदत डालने के लिए शायद अच्छा है , उस समय के लिए जब यह वास्तव में मायने रखता है।
foo="$fooworld"
? मैं नहीं
fooworld
। जैसा कि ब्रेसिज़ के साथ किया जाता है, उसे अलग करना foo="${foo}world"
...
बैश भी एक +=
ऑपरेटर का समर्थन करता है जैसा कि इस कोड में दिखाया गया है:
$ A="X Y"
$ A+=" Z"
$ echo "$A"
X Y Z
export A+="Z"
या शायद A
चर को केवल एक बार निर्यात करने की आवश्यकता है?
export A+=Z
साथ ही साथ काफी अच्छी तरह से काम करता है।
#!/bin/sh
इस निर्माण का उपयोग करने वाली स्क्रिप्ट में कभी भी उपयोग नहीं करना चाहिए ।
bash
और कुछ अन्य उन्नत शेल में समर्थित है । यह busybox sh
या dash
(जो /bin/sh
बहुत डिस्ट्रोस पर है) के तहत काम नहीं करेगा , या कुछ अन्य गोले जैसे /bin/sh
FreeBSD पर प्रदान किए जाएंगे।
चूंकि यह प्रश्न विशेष रूप से बैश के लिए खड़ा है , इसलिए उत्तर का मेरा पहला भाग इसे ठीक से करने के विभिन्न तरीके प्रस्तुत करेगा:
+=
: चर के लिए आवेदन करेंवाक्यविन्यास +=
का उपयोग विभिन्न तरीकों से किया जा सकता है:
var+=...
(क्योंकि मैं मितव्ययी हूँ, मैं केवल दो चरों का उपयोग करेगा foo
और a
और उसके बाद पूरे जवाब में एक ही फिर से उपयोग करें। ;-)
a=2
a+=4
echo $a
24
स्टैक ओवरफ़्लो प्रश्न सिंटैक्स का उपयोग करना ,
foo="Hello"
foo+=" World"
echo $foo
Hello World
ठीक काम करता है!
((var+=...))
चर a
एक स्ट्रिंग है, लेकिन एक पूर्णांक भी है
echo $a
24
((a+=12))
echo $a
36
var+=(...)
हमारा a
भी केवल एक तत्व की एक सरणी है।
echo ${a[@]}
36
a+=(18)
echo ${a[@]}
36 18
echo ${a[0]}
36
echo ${a[1]}
18
ध्यान दें कि कोष्ठक के बीच, एक अंतरिक्ष अलग सरणी है । यदि आप अपने सरणी में स्ट्रिंग युक्त रिक्त स्थान संग्रहीत करना चाहते हैं, तो आपको उन्हें संलग्न करना होगा:
a+=(one word "hello world!" )
bash: !": event not found
हम्म .. यह एक बग नहीं है, लेकिन एक विशेषता है ... को विकसित करने की कोशिश करने से रोकने के लिए !"
, आप कर सकते हैं:
a+=(one word "hello world"! 'hello world!' $'hello world\041')
declare -p a
declare -a a='([0]="36" [1]="18" [2]="one" [3]="word" [4]="hello world!" [5]="h
ello world!" [6]="hello world!")'
printf
: अंतर्निहित निर्माण कमांड का उपयोग करके पुनः निर्माण करेंprintf
निर्मित कमांड स्ट्रिंग प्रारूप ड्राइंग का एक शक्तिशाली तरीका देता है। चूंकि यह बैश बिलिन है , इसलिए प्रिंटिंग पर बदले हुए स्वरूपित स्ट्रिंग को चर में भेजने का विकल्प है stdout
:
echo ${a[@]}
36 18 one word hello world! hello world! hello world!
इस सरणी में सात तार हैं । इसलिए हम एक स्वरूपित स्ट्रिंग का निर्माण कर सकते हैं जिसमें सात स्थितीय तर्क हैं:
printf -v a "%s./.%s...'%s' '%s', '%s'=='%s'=='%s'" "${a[@]}"
echo $a
36./.18...'one' 'word', 'hello world!'=='hello world!'=='hello world!'
या हम एक तर्क प्रारूप स्ट्रिंग का उपयोग कर सकते हैं जो कई तर्क के रूप में दोहराया जाएगा ...
ध्यान दें कि हमारी a
अभी भी एक सरणी है! केवल पहला तत्व बदल गया है!
declare -p a
declare -a a='([0]="36./.18...'\''one'\'' '\''word'\'', '\''hello world!'\''=='\
''hello world!'\''=='\''hello world!'\''" [1]="18" [2]="one" [3]="word" [4]="hel
lo world!" [5]="hello world!" [6]="hello world!")'
बैश के तहत, जब आप सूचकांक निर्दिष्ट किए बिना एक चर नाम का उपयोग करते हैं, तो आप हमेशा पहले तत्व को ही संबोधित करते हैं!
तो हमारे सात क्षेत्र सरणी को पुनः प्राप्त करने के लिए, हमें केवल 1 तत्व को फिर से सेट करना होगा:
a=36
declare -p a
declare -a a='([0]="36" [1]="18" [2]="one" [3]="word" [4]="hello world!" [5]="he
llo world!" [6]="hello world!")'
कई तर्क के साथ एक तर्क प्रारूप स्ट्रिंग:
printf -v a[0] '<%s>\n' "${a[@]}"
echo "$a"
<36>
<18>
<one>
<word>
<hello world!>
<hello world!>
<hello world!>
foo="Hello"
printf -v foo "%s World" $foo
echo $foo
Hello World
नोटा: के उपयोग डबल उद्धरण तार, जिनमें शामिल है जोड़ तोड़ के लिए उपयोगी हो सकता है spaces
, tabulations
और / याnewlines
printf -v foo "%s World" "$foo"
के तहत POSIX खोल, आप का उपयोग नहीं कर सकता है bashisms , इसलिए कोई है builtin printf
।
लेकिन आप बस कर सकते हैं:
foo="Hello"
foo="$foo World"
echo $foo
Hello World
printf
यदि आप अधिक परिष्कृत निर्माणों का उपयोग करना चाहते हैं, तो आपको एक कांटा (नई बच्चे की प्रक्रिया है जो काम करती है और परिणाम को वापस लौटाती है stdout
) का उपयोग करना होगा:
foo="Hello"
foo=$(printf "%s World" "$foo")
echo $foo
Hello World
ऐतिहासिक रूप से, आप कांटा का परिणाम प्राप्त करने के लिए backticks का उपयोग कर सकते हैं :
foo="Hello"
foo=`printf "%s World" "$foo"`
echo $foo
Hello World
लेकिन यह घोंसले के शिकार के लिए आसान नहीं है :
foo="Today is: "
foo=$(printf "%s %s" "$foo" "$(date)")
echo $foo
Today is: Sun Aug 4 11:58:23 CEST 2013
बैकटिक्स के साथ, आपको बैकस्लैश के साथ आंतरिक कांटे से बचना होगा :
foo="Today is: "
foo=`printf "%s %s" "$foo" "\`date\`"`
echo $foo
Today is: Sun Aug 4 11:59:10 CEST 2013
+=
ऑपरेटर भी बहुत तेजी से है $a="$a$b"
मेरी परीक्षणों में .. कौन सा समझ में आता है।
var=${var}.sh
अन्य उत्तरों से उदाहरण याद कर रहा है, जो बहुत उपयोगी है।
bash
केवल के साथ खोल +=
ऑपरेटर? मैं देखना चाहता हूँ अगर यह होता है पोर्टेबल पर्याप्त
+=
ऑपरेटर के साथ एकमात्र शेल नहीं हूं , लेकिन यह सभी तरीके बशीज़ हैं , इसलिए पोर्टेबल नहीं हैं! यहां तक कि आप गलत बैश संस्करण के मामले में विशेष बग का सामना कर सकते हैं!
आप भी यह कर सकते हैं:
$ var="myscript"
$ echo $var
myscript
$ var=${var}.sh
$ echo $var
myscript.sh
var=myscript;var=$var.sh;echo $var
एक ही प्रभाव होगा (यह काम के तहत बाश, डैश, बिजीबॉक्स और अन्य)।
echo $var2
कि उत्पादन नहीं करता हैmyscript2
.
वैरिएबल नाम में डॉट अवैध होने के कारण यह काम करता है । अगर मेरे जवाब को कोई echo ${var}2
और देखता है या नहीं
bla=hello
laber=kthx
echo "${bla}ohai${laber}bye"
उत्पादन करेगा
helloohaikthxbye
यह तब उपयोगी $blaohai
होता है जब
एक चर को त्रुटि नहीं मिलती है। या यदि आपके स्ट्रिंग्स में स्थान या अन्य विशेष वर्ण हैं। "${foo}"
ठीक से तुम में डाल कुछ बच जाता है।
foo="Hello "
foo="$foo World"
जिस तरह से मैं इस समस्या को हल करेंगे बस है
$a$b
उदाहरण के लिए,
a="Hello"
b=" World"
c=$a$b
echo "$c"
जो पैदा करता है
Hello World
यदि आप एक स्ट्रिंग को किसी अन्य स्ट्रिंग के साथ जोड़ने की कोशिश करते हैं, उदाहरण के लिए,
a="Hello"
c="$a World"
तब echo "$c"
उत्पादन होगा
Hello World
एक अतिरिक्त जगह के साथ।
$aWorld
काम नहीं करता है, जैसा कि आप कल्पना कर सकते हैं, लेकिन
${a}World
पैदा करता है
HelloWorld
${a}\ World
उत्पादनHello World
c=$a$b
यहाँ भी वही काम c=$a World
होगा (जो World
कमांड के रूप में चलने की कोशिश करेगा )। मुझे लगता है कि चर का विस्तार होने से पहले असाइनमेंट को पार्स किया जाता है ..
यहाँ एक संक्षिप्त सारांश है कि अधिकांश उत्तर किस बारे में बात कर रहे हैं।
मान लें कि हमारे पास दो चर हैं और $ 1 'एक' पर सेट है:
set one two
a=hello
b=world
नीचे दी गई तालिका विभिन्न संदर्भों जहां हम के मूल्यों को जोड़ सकते हैं बताते हैं a
और b
, एक नया चर बनाने के लिए c
।
Context | Expression | Result (value of c)
--------------------------------------+-----------------------+---------------------
Two variables | c=$a$b | helloworld
A variable and a literal | c=${a}_world | hello_world
A variable and a literal | c=$1world | oneworld
A variable and a literal | c=$a/world | hello/world
A variable, a literal, with a space | c=${a}" world" | hello world
A more complex expression | c="${a}_one|${b}_2" | hello_one|world_2
Using += operator (Bash 3.1 or later) | c=$a; c+=$b | helloworld
Append literal with += | c=$a; c+=" world" | hello world
कुछ नोट:
+=
एक प्रदर्शन के दृष्टिकोण से बेहतर है अगर एक बड़ी स्ट्रिंग का निर्माण छोटे वेतन वृद्धि में किया जा रहा है, खासकर एक लूप में{}
उनके विस्तार को अस्वीकार करने के लिए चर नामों का उपयोग करें (जैसा कि ऊपर तालिका में पंक्ति 2 में है)। जैसा कि 3 और 4 पंक्तियों पर देखा जाता है, {}
जब तक कि एक चर को स्ट्रिंग के साथ संकलित नहीं किया जा सकता है, तब तक इसकी कोई आवश्यकता नहीं है जो एक वर्ण से शुरू होता है जो शेल चर नाम में एक मान्य पहला वर्ण है, जो वर्णमाला या अंडरस्कोर है।यह सभी देखें:
फिर भी एक और दृष्टिकोण ...
> H="Hello "
> U="$H""universe."
> echo $U
Hello universe.
... और अभी तक एक और एक।
> H="Hello "
> U=$H"universe."
> echo $U
Hello universe.
यदि आप किसी अंडरस्कोर की तरह कुछ जोड़ना चाहते हैं, तो एस्केप (\) का उपयोग करें
FILEPATH=/opt/myfile
यह काम नहीं करता है:
echo $FILEPATH_$DATEX
यह ठीक काम करता है:
echo $FILEPATH\\_$DATEX
echo $a\_$b
क्या करेंगे। जैसा कि निक ओ'लाई की टिप्पणी में संकेत दिया गया है कि अंडरस्कोर एक नियमित चरित्र है। सफेद रिक्त स्थान की हैंडलिंग स्ट्रिंग्स, प्रतिध्वनि और संघनन के लिए बहुत अधिक संवेदनशील होती है --- कोई भी \
इस धागे को अच्छी तरह से उपयोग और पढ़ सकता है क्योंकि यह मुद्दा अब और फिर वापस आता है।
उद्धरण चिह्नों के साथ सबसे सरल तरीका:
B=Bar
b=bar
var="$B""$b""a"
echo "Hello ""$var"
var=$B$b"a"; echo Hello\ $var
मुझे विश्वास है
आप उद्धरण के बिना संक्षिप्त कर सकते हैं। यहाँ एक उदाहरण है:
$Variable1 Open
$Variable2 Systems
$Variable3 $Variable1$Variable2
$echo $Variable3
यह अंतिम कथन "OpenSystems" (बिना उद्धरण के) छापेगा।
यह बैश स्क्रिप्ट का एक उदाहरण है:
v1=hello
v2=world
v3="$v1 $v2"
echo $v3 # Output: hello world
echo "$v3" # Output: hello world
यहां तक कि अगर + = ऑपरेटर को अब अनुमति दी गई है, तो इसे 2004 में बैश 3.1 में पेश किया गया है ।
पुराने बैश संस्करणों पर इस ऑपरेटर का उपयोग करने वाली कोई भी स्क्रिप्ट "कमांड नहीं मिली" त्रुटि के साथ विफल हो जाएगी यदि आप भाग्यशाली हैं, या "अप्रत्याशित टोकन के पास एक सिंटैक्स त्रुटि"।
उन लोगों के लिए जो पिछड़े संगतता के बारे में परवाह करते हैं, पुराने मानक बैश संघनन विधियों के साथ छड़ी करते हैं, जैसे चुने हुए उत्तर में उल्लिखित हैं:
foo="Hello"
foo="$foo World"
echo $foo
> Hello World
मैं ${}
स्ट्रिंग में चर का विस्तार करने के लिए घुंघराले कोष्ठक का उपयोग करना पसंद करता हूं :
foo="Hello"
foo="${foo} World"
echo $foo
> Hello World
घुंघराले कोष्ठक निरंतर स्ट्रिंग उपयोग के लिए फिट होंगे:
foo="Hello"
foo="${foo}World"
echo $foo
> HelloWorld
अन्यथा उपयोग करने foo = "$fooWorld"
से काम नहीं चलेगा।
यदि आप जो करने की कोशिश कर रहे हैं वह एक स्ट्रिंग को कई लाइनों में विभाजित करना है , तो आप बैकस्लैश का उपयोग कर सकते हैं:
$ a="hello\
> world"
$ echo $a
helloworld
बीच में एक जगह के साथ:
$ a="hello \
> world"
$ echo $a
hello world
यह भी बीच में केवल एक स्थान जोड़ता है:
$ a="hello \
> world"
$ echo $a
hello world
सुरक्षित तरीका:
a="AAAAAAAAAAAA"
b="BBBBBBBBBBBB"
c="CCCCCCCCCCCC"
d="DD DD"
s="${a}${b}${c}${d}"
echo "$s"
AAAAAAAAAAAABBBBBBBBBBBBCCCCCCCCCCCCDD DD
रिक्त स्थान वाले स्ट्रिंग्स कमांड का हिस्सा बन सकते हैं, इन त्रुटियों से बचने के लिए "$ XXX" और "$ {XXX}" का उपयोग करें।
प्लस + = के बारे में अन्य उत्तर पर एक नज़र डालें
d=DD DD
दे देंगे DD: command not found
--- ध्यान दें कि अंतिम डीडी है, बल्कि ऐसा नहीं मिला है। यदि सभी ऑपरेंड ठीक से स्वरूपित हैं और पहले से ही आवश्यक स्थान हैं, तो आप s=${a}${b}${c}${d}; echo $s
कम उद्धरण चिह्नों के साथ बस संक्षिप्त कर सकते हैं । इसके अलावा, आप \
इन मुद्दों से बचने के लिए (बच गए व्हाट्सएप) का उपयोग कर सकते हैं --- d=echo\ echo
कोई इको इनवोकेशन लॉन्च नहीं करेगा, जबकि d=echo echo
होगा।
a="Hello,"
a=$a" World!"
echo $a
इस तरह आप दो तारों को समेटते हैं।
यदि यह " World"
मूल स्ट्रिंग में जोड़ने के अपने उदाहरण के रूप में है, तो यह हो सकता है:
#!/bin/bash
foo="Hello"
foo=$foo" World"
echo $foo
उत्पादन:
Hello World
var1='hello'
var2='world'
var3=$var1" "$var2
echo $var3
var3=$var1\ $var2
समान प्रभाव है
प्रदर्शन के बारे में आवाज उठाई जाती है, लेकिन कोई डेटा पेश नहीं किया जाता है। मुझे एक सरल परीक्षा का सुझाव दें।
(नोट: date
macOS पर नैनोसेकेंड की पेशकश नहीं है, इसलिए इसे लिनक्स पर किया जाना चाहिए।)
मैंने सामग्री के साथ GitHub पर append_test.sh बनाया है :
#!/bin/bash -e
output(){
ptime=$ctime;
ctime=$(date +%s.%N);
delta=$(bc <<<"$ctime - $ptime");
printf "%2s. %16s chars time: %s delta: %s\n" $n "$(bc <<<"10*(2^$n)")" $ctime $delta;
}
method1(){
echo 'Method: a="$a$a"'
for n in {1..32}; do a="$a$a"; output; done
}
method2(){
echo 'Method: a+="$a"'
for n in {1..32}; do a+="$a"; output; done
}
ctime=0; a="0123456789"; time method$1
टेस्ट 1:
$ ./append_test.sh 1
Method: a="$a$a"
1. 20 chars time: 1513640431.861671143 delta: 1513640431.861671143
2. 40 chars time: 1513640431.865036344 delta: .003365201
3. 80 chars time: 1513640431.868200952 delta: .003164608
4. 160 chars time: 1513640431.871273553 delta: .003072601
5. 320 chars time: 1513640431.874358253 delta: .003084700
6. 640 chars time: 1513640431.877454625 delta: .003096372
7. 1280 chars time: 1513640431.880551786 delta: .003097161
8. 2560 chars time: 1513640431.883652169 delta: .003100383
9. 5120 chars time: 1513640431.886777451 delta: .003125282
10. 10240 chars time: 1513640431.890066444 delta: .003288993
11. 20480 chars time: 1513640431.893488326 delta: .003421882
12. 40960 chars time: 1513640431.897273327 delta: .003785001
13. 81920 chars time: 1513640431.901740563 delta: .004467236
14. 163840 chars time: 1513640431.907592388 delta: .005851825
15. 327680 chars time: 1513640431.916233664 delta: .008641276
16. 655360 chars time: 1513640431.930577599 delta: .014343935
17. 1310720 chars time: 1513640431.954343112 delta: .023765513
18. 2621440 chars time: 1513640431.999438581 delta: .045095469
19. 5242880 chars time: 1513640432.086792464 delta: .087353883
20. 10485760 chars time: 1513640432.278492932 delta: .191700468
21. 20971520 chars time: 1513640432.672274631 delta: .393781699
22. 41943040 chars time: 1513640433.456406517 delta: .784131886
23. 83886080 chars time: 1513640435.012385162 delta: 1.555978645
24. 167772160 chars time: 1513640438.103865613 delta: 3.091480451
25. 335544320 chars time: 1513640444.267009677 delta: 6.163144064
./append_test.sh: fork: Cannot allocate memory
टेस्ट 2:
$ ./append_test.sh 2
Method: a+="$a"
1. 20 chars time: 1513640473.460480052 delta: 1513640473.460480052
2. 40 chars time: 1513640473.463738638 delta: .003258586
3. 80 chars time: 1513640473.466868613 delta: .003129975
4. 160 chars time: 1513640473.469948300 delta: .003079687
5. 320 chars time: 1513640473.473001255 delta: .003052955
6. 640 chars time: 1513640473.476086165 delta: .003084910
7. 1280 chars time: 1513640473.479196664 delta: .003110499
8. 2560 chars time: 1513640473.482355769 delta: .003159105
9. 5120 chars time: 1513640473.485495401 delta: .003139632
10. 10240 chars time: 1513640473.488655040 delta: .003159639
11. 20480 chars time: 1513640473.491946159 delta: .003291119
12. 40960 chars time: 1513640473.495354094 delta: .003407935
13. 81920 chars time: 1513640473.499138230 delta: .003784136
14. 163840 chars time: 1513640473.503646917 delta: .004508687
15. 327680 chars time: 1513640473.509647651 delta: .006000734
16. 655360 chars time: 1513640473.518517787 delta: .008870136
17. 1310720 chars time: 1513640473.533228130 delta: .014710343
18. 2621440 chars time: 1513640473.560111613 delta: .026883483
19. 5242880 chars time: 1513640473.606959569 delta: .046847956
20. 10485760 chars time: 1513640473.699051712 delta: .092092143
21. 20971520 chars time: 1513640473.898097661 delta: .199045949
22. 41943040 chars time: 1513640474.299620758 delta: .401523097
23. 83886080 chars time: 1513640475.092311556 delta: .792690798
24. 167772160 chars time: 1513640476.660698221 delta: 1.568386665
25. 335544320 chars time: 1513640479.776806227 delta: 3.116108006
./append_test.sh: fork: Cannot allocate memory
त्रुटियों से संकेत मिलता है कि दुर्घटनाग्रस्त होने से पहले मेरा बैश 335.54432 एमबी तक का था। आप अधिक दानेदार ग्राफ और विफलता बिंदु प्राप्त करने के लिए एक निरंतर अपील करने के लिए डेटा को दोगुना करने से कोड बदल सकते हैं । लेकिन मुझे लगता है कि आपको यह तय करने के लिए पर्याप्त जानकारी देनी चाहिए कि क्या आप परवाह करते हैं। व्यक्तिगत रूप से, 100 एमबी से कम मैं नहीं। आपकी माइलेज भिन्न हो सकती है।
join <(LANG=C bash -c 'a="a" c=1 last=${EPOCHREALTIME//.};while :;do a+=$a;now=${EPOCHREALTIME//.};echo $((c++)) ${#a} $((now-last));last=$now;done') <(LANG=C bash -c 'a="a" c=1 last=${EPOCHREALTIME//.};while :;do a=$a$a;now=${EPOCHREALTIME//.};echo $((c++)) ${#a} $((now-last));last=$now;done')|sed -ue '1icnt strlen a+=$a a=$a$a' -e 's/^\([0-9]\+\) \([0-9]\+\) \([0-9]\+\) \2/\1 \2 \3/' | xargs printf "%4s %11s %9s %9s\n"
(उत्पादक मेजबान पर यह कोशिश नहीं !!;)
ध्यान दें कि यह काम नहीं करेगा
foo=HELLO
bar=WORLD
foobar=PREFIX_$foo_$bar
के रूप में यह $ फू छोड़ने के लिए लगता है और आप के साथ छोड़ देता है:
PREFIX_WORLD
लेकिन यह काम करेगा:
foobar=PREFIX_"$foo"_"$bar"
और सही आउटपुट के साथ आपको छोड़ दें:
PREFIX_HELLO_WORLD
मैं इसे इस तरह से करता हूं जब सुविधाजनक: एक इनलाइन कमांड का उपयोग करें!
echo "The current time is `date`"
echo "Current User: `echo $USER`"
date "+The current time is %a %b %d %Y +%T"
हैं echo ...$(date)
। हालिया बैश के तहत, आप लिख सकते हैं printf "The current time is %(%a %b %d %Y +%T)T\n" -1
:।
मेरी राय में, दो तारों को समतल करने का सबसे सरल तरीका एक फ़ंक्शन लिखना है जो आपके लिए करता है, फिर उस फ़ंक्शन का उपयोग करें।
function concat ()
{
prefix=$1
suffix=$2
echo "${prefix}${suffix}"
}
foo="Super"
bar="man"
concat $foo $bar # Superman
alien=$(concat $foo $bar)
echo $alien # Superman
मुझे एक त्वरित कार्य करना पसंद है।
#! /bin/sh -f
function combo() {
echo $@
}
echo $(combo 'foo''bar')
फिर भी एक बिल्ली की त्वचा के लिए एक और तरीका है। इस बार कार्यों के साथ: डी
मैं अभी तक PHP के बारे में नहीं जानता, लेकिन यह लिनक्स बैश में काम करता है। यदि आप इसे एक चर पर प्रभावित नहीं करना चाहते हैं, तो आप यह कोशिश कर सकते हैं:
read pp; *# Assumes I will affect Hello to pp*
pp=$( printf $pp ;printf ' World'; printf '!');
echo $pp;
>Hello World!
आप 'हैलो' या '!' के बजाय एक और वेरिएबल रख सकते हैं। आप और भी तार जोड़ सकते हैं।
foo="Hello"
foo=$foo" World"
echo $foo
इसके बजाय "#! / बिन / श" के लिए काम किया