[英]How to call one shell script from another shell script?
我有两个shell脚本a.sh
和b.sh
。
我怎么能叫b.sh
从shell脚本中a.sh
?
有几种不同的方法可以做到这一点:
使另一个脚本可执行,在顶部添加#!/bin/bash
行,并将文件所在的路径添加到 $PATH 环境变量。 然后就可以作为普通命令调用了;
或者使用source
命令(别名是.
)调用它,如下所示: source /path/to/script
;
或者使用bash
命令执行: /bin/bash /path/to/script
;
第一种和第三种方法将脚本作为另一个进程执行,因此其他脚本中的变量和函数将无法访问。
第二种方法在第一个脚本的进程中执行脚本,并从另一个脚本中提取变量和函数,以便它们可以从调用脚本中使用。
在第二种方法中,如果您在第二个脚本中使用exit
,它也会退出第一个脚本。 这不会发生在第一种和第三种方法中。
看一下这个。
#!/bin/bash
echo "This script is about to run another script."
sh ./script.sh
echo "This script has just run another script."
有几种方法可以做到这一点。 执行脚本的终端:
#!/bin/bash
SCRIPT_PATH="/path/to/script.sh"
# Here you execute your script
"$SCRIPT_PATH"
# or
. "$SCRIPT_PATH"
# or
source "$SCRIPT_PATH"
# or
bash "$SCRIPT_PATH"
# or
eval '"$SCRIPT_PATH"'
# or
OUTPUT=$("$SCRIPT_PATH")
echo $OUTPUT
# or
OUTPUT=`"$SCRIPT_PATH"`
echo $OUTPUT
# or
("$SCRIPT_PATH")
# or
(exec "$SCRIPT_PATH")
所有这些对于带空格的路径都是正确的!!!
我正在寻找的答案:
( exec "path/to/script" )
如前所述, exec
替换 shell 而不创建新进程。 但是,我们可以将它放在子shell 中,这是使用括号完成的。
编辑:实际上( "path/to/script" )
就足够了。
如果您在同一目录中有另一个文件,您可以执行以下操作:
bash another_script.sh
要么
source another_script.sh
要么
. another_script.sh
当您使用bash
而不是source
,脚本无法更改父脚本的环境。 .
command 是 POSIX 标准,而source
command 是更易读的 bash 同义词.
(我更喜欢source
不是.
)。 如果您的脚本驻留在别处,只需提供该脚本的路径。 相对路径和完整路径都应该有效。
依赖于取决于。 简而言之...如果您想在当前控制台上加载变量并执行,您可以在代码中使用source myshellfile.sh
。 例子:
!#/bin/bash
set -x
echo "This is an example of run another INTO this session."
source my_lib_of_variables_and_functions.sh
echo "The function internal_function() is defined into my lib."
returned_value=internal_function()
echo $this_is_an_internal_variable
set +x
如果您只想执行一个文件,而唯一让您感兴趣的是结果,您可以执行以下操作:
!#/bin/bash
set -x
./executing_only.sh
sh i_can_execute_this_way_too.sh
bash or_this_way.sh
set +x
我希望对你有帮助。 谢谢。
您可以使用/bin/sh
调用或执行另一个脚本(通过您的实际脚本):
# cat showdate.sh
#!/bin/bash
echo "Date is: `date`"
# cat mainscript.sh
#!/bin/bash
echo "You are login as: `whoami`"
echo "`/bin/sh ./showdate.sh`" # exact path for the script file
输出将是:
# ./mainscript.sh
You are login as: root
Date is: Thu Oct 17 02:56:36 EDT 2013
首先,您必须包含您调用的文件:
#!/bin/bash
. includes/included_file.sh
然后你像这样调用你的函数:
#!/bin/bash
my_called_function
只需添加一行您在终端中键入的内容即可执行脚本!
例如:
#!bin/bash
./myscript.sh &
如果要执行的脚本不在同一目录下,则使用脚本的完整路径即可。
例如:`/home/user/script-directory/./myscript.sh &
简单的来源会帮助你。 对于前。
#!/bin/bash
echo "My shell_1"
source my_script1.sh
echo "Back in shell_1"
这对我有用,这是执行另一个脚本的主 sh 脚本的内容。
#!/bin/bash
source /path/to/other.sh
最佳答案建议将#!/bin/bash
行添加到被调用的子脚本的第一行。 但是,即使您添加了shebang,在子shell 中运行脚本并捕获输出也会更快* :
$(source SCRIPT_NAME)
当您想继续运行相同的解释器(例如从 bash 到另一个 bash 脚本)并确保不执行子脚本的 shebang 行时,这会起作用。
例如:
#!/bin/bash
SUB_SCRIPT=$(mktemp)
echo "#!/bin/bash" > $SUB_SCRIPT
echo 'echo $1' >> $SUB_SCRIPT
chmod +x $SUB_SCRIPT
if [[ $1 == "--source" ]]; then
for X in $(seq 100); do
MODE=$(source $SUB_SCRIPT "source on")
done
else
for X in $(seq 100); do
MODE=$($SUB_SCRIPT "source off")
done
fi
echo $MODE
rm $SUB_SCRIPT
输出:
~ ❯❯❯ time ./test.sh
source off
./test.sh 0.15s user 0.16s system 87% cpu 0.360 total
~ ❯❯❯ time ./test.sh --source
source on
./test.sh --source 0.05s user 0.06s system 95% cpu 0.114 total
*例如,当病毒或安全工具在设备上运行时,执行新进程可能需要额外的 100 毫秒。
#!/bin/bash
# Here you define the absolute path of your script
scriptPath="/home/user/pathScript/"
# Name of your script
scriptName="myscript.sh"
# Here you execute your script
$scriptPath/$scriptName
# Result of script execution
result=$?
chmod a+x /path/to/file-to-be-executed
那是我唯一需要的东西。 一旦要执行的脚本像这样可以执行,您(至少在我的情况下)在调用脚本时不需要任何其他额外的操作,例如sh
或./
。
感谢@Nathan Lilienthal 的评论
pathToShell="/home/praveen/"
chmod a+x $pathToShell"myShell.sh"
sh $pathToShell"myShell.sh"
假设新建文件为“/home/satya/app/app_specific_env”,文件内容如下
#!bin/bash
export FAV_NUMBER="2211"
将此文件引用附加到 ~/.bashrc 文件
source /home/satya/app/app_specific_env
当您重新启动机器或重新登录时, echo $FAV_NUMBER
在终端中尝试echo $FAV_NUMBER
。 它将输出值。
以防万一,如果您想立即看到效果,请在命令行中输入source ~/.bashrc
。
从其他文件导入函数存在一些问题。
第一:您不需要执行此文件。 最好不要这样做! 只需添加
. file
导入所有函数。 所有这些都好像在您的文件中定义了一样。
第二:你可能定义了同名的函数。 它将被覆盖。 这不好。 你可以这样声明
declare -f new_function_name=old_function_name
只有在那之后才能导入。 所以你可以用新名称调用旧函数。
第三:您只能导入文件中定义的完整函数列表。 如果有些不需要,您可以取消设置它们。 但是如果你在 unset 之后重写你的函数,它们就会丢失。 但是,如果您如上所述设置对它的引用,则可以在取消设置后使用相同的名称进行恢复。
最后在普通的导入过程中是危险的,并不是那么简单。 当心! 您可以编写脚本来更轻松、更安全地执行此操作。 如果您只使用部分功能(不是全部),最好将它们拆分到不同的文件中。 不幸的是,这种技术在 bash 中做得不好。 例如在 python 和其他一些脚本语言中,它既简单又安全。 可以只使用自己的名称部分导入需要的函数。 我们都希望在下一个灌木版本中完成相同的功能。 但是现在我们必须编写许多额外的 cod 才能做你想做的事。
使用反引号。
$ ./script-that-consumes-argument.sh `sh script-that-produces-argument.sh`
然后获取生产者脚本的输出作为消费者脚本的参数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.