假设我有这样的脚本:

export.bash:

#! /usr/bin/env bash
export VAR="HELLO, VARIABLE"

当我执行脚本并试图访问$VAR时,我没有得到任何值!

echo $VAR

是否有一种方法通过执行export来访问$VAR。没有来源的Bash ?


当前回答

如果你想为调用shell设置一个变量,有一个使用c unix套接字的健壮方法。 测试结果如下:

$ ./a.out &
[1] 5363
$ ./b.out 123;a=`./b.out`;echo ${a}
123
[1]+  Done                    ./a.out

参见我的github上的a.c, b.c和a.h。

其他回答

为了先导出VAR变量,最合理、最合适的工作方式是对变量进行source:

. ./export.bash

or

source ./export.bash

现在当从主shell中回显时,它工作:

echo $VAR
HELLO, VARIABLE

我们现在将重置VAR:

export VAR=""
echo $VAR

现在我们将执行一个脚本来获取变量的源,然后将其取消设置:

./test-export.sh
HELLO, VARIABLE
--
.

代码:test-export.sh文件

#!/bin/bash
# Source env variable
source ./export.bash

# echo out the variable in test script
echo $VAR

# unset the variable
unset VAR
# echo a few dotted lines
echo "---"
# now return VAR which is blank
echo $VAR

这里有一种方法:

请注意:导出仅限于在你的主控制台中执行导出的脚本-所以就cron作业而言,我会像下面的控制台一样添加它…对于命令部分仍然有问题:下面是你如何从你的shell运行:

在您的命令提示符(只要导出。Bash文件有多个echo值)

IFS=$'\n'; for entries in $(./export.bash); do  export $entries;  done; ./v1.sh
HELLO THERE
HI THERE

文件cat v1.sh

#!/bin/bash
echo $VAR
echo $VAR1

现在,只要这是为你的使用-你可以让变量在任何时候为你的脚本可用,做一个Bash别名像这样:

myvars ./v1.sh
HELLO THERE
HI THERE

echo $VAR

.

把这个添加到你的bashrc文件中:

function myvars() {
    IFS=$'\n';
    for entries in $(./export.bash); do  export $entries;  done;

    "$@";

    for entries in $(./export.bash); do variable=$(echo $entries|awk -F"=" '{print $1}'); unset $variable;
    done
}

来源你的.bashrc文件,你可以做如上任何时候…

不管怎样,回到剩下的部分……

这使得它在全球范围内可用,然后执行脚本…

简单地回显它并在回显上运行export !

文件export.bash

#!/bin/bash
echo "VAR=HELLO THERE"

现在在脚本或控制台运行:

export "$(./export.bash)"

Try:

echo $VAR
HELLO THERE

多个值,只要你知道你期望在另一个脚本中使用上述方法:

文件export.bash

#!/bin/bash
echo "VAR=HELLO THERE"
echo "VAR1=HI THERE"

文件test-export.sh

#!/bin/bash

IFS=$'\n'
for entries in $(./export.bash); do
    export $entries
done

echo "round 1"
echo $VAR
echo $VAR1

for entries in $(./export.bash); do
    variable=$(echo $entries|awk -F"=" '{print $1}');
    unset $variable
done

echo "round 2"
echo $VAR
echo $VAR1

现在来看结果

./test-export.sh
round 1
HELLO THERE
HI THERE
round 2


.

最后的最终更新自动分配,读取变量:

./test-export.sh
Round 0 - Export out then find variable name -
Set current variable to the variable exported then echo its value
$VAR has value of HELLO THERE
$VAR1 has value of HI THERE
round 1 - we know what was exported and we will echo out known variables
HELLO THERE
HI THERE
Round 2 - We will just return the variable names and unset them
round 3 - Now we get nothing back

脚本:

文件test-export.sh

#!/bin/bash

IFS=$'\n'
echo "Round 0 - Export out then find variable name - "
echo "Set current variable to the variable exported then echo its value"
for entries in $(./export.bash); do
    variable=$(echo $entries|awk -F"=" '{print $1}');
    export $entries
    eval current_variable=\$$variable
    echo "\$$variable has value of $current_variable"
done


echo "round 1 - we know what was exported and we will echo out known variables"
echo $VAR
echo $VAR1

echo "Round 2 - We will just return the variable names and unset them "
for entries in $(./export.bash); do
    variable=$(echo $entries|awk -F"=" '{print $1}');
    unset $variable
done

echo "round 3 - Now we get nothing back"
echo $VAR
echo $VAR1

另一种变通方法(取决于具体情况)可能很有用:创建另一个继承导出变量的bash脚本。这是Keith Thompson回答的一个特例,所有这些缺点。

文件export.bash:

# !/bin/bash
export VAR="HELLO, VARIABLE"
bash

Now:

./export.bash
echo $VAR

这个变通方法在其他地方也有暗示,但可能不是那么清楚:

在脚本中,设置变量后,启动一个新的shell,而不是返回。

我的用例是,我有许多打开的终端,在其中一些终端中,我想要一些变量的值,而在其他终端中,我想要其他值。

由于使用source可能更难记住,这种方法的一个小优点是,当您需要一段时间才能意识到您忘记使用source时,您必须从头开始。

(对我来说,使用源脚本更有意义,因为缺失的变量会立即被注意到。)

也许你可以在~/中添加一个函数。ZSHRC或~/.bashrc。

# set my env
[ -s ~/.env ] && export MYENV=`cat ~/.env`
function myenv() { [[ -s ~/.env ]] && echo $argv > ~/.env && export MYENV=$argv }

由于使用了外部变量,可以避免使用脚本文件。

答案是否定的,但对我来说,我做了以下事情

脚本:

myExport

#! \bin\bash
export $1

我的.bashrc文件中的别名:

alias myExport='source myExport'

你仍然可以获取它,但也许这样它更有用,对其他人来说也更有趣。