在PHP中,字符串按如下方式连接在一起:

$foo = "Hello";
$foo .= " World";

在这里,$foo变成了“Hello World”。

这是如何在Bash中实现的?


当前回答

我想从列表中创建一个字符串。找不到答案,所以我把它贴在这里。以下是我所做的:

list=(1 2 3 4 5)
string=''

for elm in "${list[@]}"; do
    string="${string} ${elm}"
done

echo ${string}

然后得到以下输出:

1 2 3 4 5

其他回答

foo="Hello "
foo="$foo World"

     

默认情况下,Bash中的变量和数组(索引或关联*)始终是字符串,但可以在声明内置函数中使用标志,为它们提供“integer”(-i)或“reference”**(-n)等属性,从而改变它们的行为方式。

Bash算术接受ASCII/字符串数字作为输入,因此实际使用integer属性的原因很少。

此外,变量值不能包含ASCII NULL(即8位零),因为通常使用以空结尾的C字符串来实现它们。

*即一个或多个键+值对。**参考变量扩展为另一个变量的值,其标签被分配给参考变量

附加字符串:

$ foo=Hello
$ foo+=' world!'
$ echo "$foo"

Hello world!

$ num=3
$ num+=4
echo "$num"

34 # Appended string (not a sum)

使用整数属性的原因之一是它改变了+=赋值运算符的行为:

$ declare -i num=3
$ num+=4
echo "$num"

7 # Sum

请注意,这不适用于-=、/=等,除非在算术((())和$(()()))中执行,在算术中,使用或不使用整数属性时,数字已被视为相同。有关这些运算符的完整列表,请参见manbash的“算术求值”一节,这些运算符与C相同。

+=赋值运算符也可用于将新元素附加到索引数组(AKA“列表”):

$ foo=(one)
$ foo+=(two)
$ printf 'Separate element: %s\n' "${foo[@]}"

Separate element: one
Separate element: two

另一种常见的方法是使用计数器:

$ foo[c++]=one
$ foo[c++]=two

POSIX shell不使用+=赋值运算符来附加字符串,因此必须这样做:

$ foo=Hello
$ foo="$foo world!"
$ echo "$foo"

Hello world!

这在Bash中也很好,因此它可以被认为是一种更可移植的语法。

即使现在允许使用+=运算符,它也已在2004年的Bash 3.1中引入。

如果幸运的话,在较旧的Bash版本上使用此运算符的任何脚本都将失败,并显示“命令未找到”错误,或“语法错误接近意外标记”。

对于那些关心向后兼容性的人,请使用较旧的标准Bash连接方法,如所选答案中提到的方法:

foo="Hello"
foo="$foo World"
echo $foo
> Hello World

在我看来,连接两个字符串的最简单方法是编写一个函数,然后使用该函数。

function concat ()
{
    prefix=$1
    suffix=$2

    echo "${prefix}${suffix}"
}

foo="Super"
bar="man"

concat $foo $bar   # Superman

alien=$(concat $foo $bar)

echo $alien        # Superman

请注意,这不会起作用

foo=HELLO
bar=WORLD
foobar=PREFIX_$foo_$bar

因为它似乎掉了$foo,给你留下了:

前缀_世界

但这将起作用:

foobar=PREFIX_"$foo"_"$bar"

并为您提供正确的输出:

前缀HELLO_WORLD