我有一个bash函数可以产生一些输出:
function scan {
echo "output"
}
如何将此输出分配给变量?
即。 VAR =扫描(当然这不起作用 - 它使VAR等于字符串“scan”)
答案 0 :(得分:111)
VAR=$(scan)
与程序完全相同。
答案 1 :(得分:14)
您可以在命令/管道中使用bash函数,就像使用常规程序一样。这些功能也可用于子壳和传递,命令替换:
VAR=$(scan)
在大多数情况下,是否能够直接实现您想要的结果。我将在下面概述特殊情况。
保留尾随新行:
命令替换的一个(通常是有用的)副作用是它将删除任意数量的尾随换行符。如果希望保留尾随换行符,可以在子shell的输出中附加一个虚拟字符,然后通过参数扩展将其删除。
function scan2 () {
local nl=$'\x0a'; # that's just \n
echo "output${nl}${nl}" # 2 in the string + 1 by echo
}
# append a character to the total output.
# and strip it with %% parameter expansion.
VAR=$(scan2; echo "x"); VAR="${VAR%%x}"
echo "${VAR}---"
打印(保留3个换行符):
output
---
使用输出参数:避免子shell(并保留换行符)
如果该功能试图实现的是"返回"将字符串转换为变量,使用bash v4.3及更高版本,可以使用名为nameref
的内容。 Namerefs允许函数获取一个或多个变量输出参数的名称。您可以将事物分配给nameref变量,就好像您更改了它指向/引用的变量。
function scan3() {
local -n outvar=$1 # -n makes it a nameref.
local nl=$'\x0a'
outvar="output${nl}${nl}" # two total. quotes preserve newlines
}
VAR="some prior value which will get overwritten"
# you pass the name of the variable. VAR will be modified.
scan3 VAR
# newlines are also preserved.
echo "${VAR}==="
打印:
output
===
这种形式有一些优点。也就是说,它允许您的函数修改调用者的环境,而无需在任何地方使用全局变量。
注意:如果你的函数很大程度上依赖于bash内置函数,使用namerefs可以极大地提高程序的性能,因为它可以避免创建一个刚刚抛弃的子shell。这通常对于经常重复使用的小功能更有意义,例如,以echo "$returnstring"
答案 2 :(得分:0)
我认为init_js应该使用declare而不是local!
function scan3() {
declare -n outvar=$1 # -n makes it a nameref.
local nl=$'\x0a'
outvar="output${nl}${nl}" # two total. quotes preserve newlines
}