👨⚕️ 主页: gis分享者
👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅!
👨⚕️ 收录于专栏:Shell 面试

文章目录
- 一、🍀前言
-
- [1.1 ☘️示例](#1.1 ☘️示例)
- [1.2 ☘️使用语法](#1.2 ☘️使用语法)
- [1.3 ☘️知识扩展](#1.3 ☘️知识扩展)
一、🍀前言
在 Shell 脚本中,Here Document 是一种通过内联多行文本为命令提供输入的方式,常用于生成文件内容或向交互式命令传递输入。。
1.1 ☘️示例
在 Shell 脚本中,here document 用于将多行文本作为标准输入送给一个命令。语法如下:
powershell
命令 <<-delimiter
多行输入
delimiter
举个例子,如果我们想创建一个文件并将多行文本写入该文件,可以这样做:
powershell
cat <<-EOF > myfile.txt
This is line 1
This is line 2
EOF
在这个例子中,文本 "This is line 1" 和 "This is line 2" 会被写入 myfile.txt 文件中。
1.2 ☘️使用语法
在 Shell 脚本中,here document(文档内联输入)通过 << 操作符实现多行文本输入,其标准语法为:
powershell
command << DELIMITER
多行文本内容
DELIMITER
关键特性及用法:
1. 基础应用
将多行文本传递给命令:
powershell
cat << EOF
第一行文本
第二行文本
包含变量的值:$PATH
EOF
2. 抑制变量扩展
使用单引号包裹分隔符可禁止变量替换:
powershell
cat << 'EOF'
原始内容 $PATH 不会被解析
EOF
3. 缩进处理
添加 - 前缀支持前置制表符(仅限 Tab):
powershell
cat <<- EOF
带缩进的文本(Tab键缩进)
EOF
4. 变量赋值
通过 read 或子 shell 捕获多行内容:
powershell
read -r -d '' content << EOF
多行文本存入变量
第二行
EOF
5. 管道传递
直接输出到其他命令:
powershell
grep "key" << EOF
line1 with key
line2 without
EOF
注意事项:
- 默认行为会解析变量、命令替换和转义字符
- 终止标记必须独占一行且无前导/后置空格
- 若需二进制安全处理,建议结合 printf 使用
此机制适用于批量配置生成、交互式脚本应答及模板化输出等场景。
1.3 ☘️知识扩展
使用 here document 有几个需要注意的点和实用技巧:
1. 自定义边界符: 在 << 之后的 "EOF" 是一个边界符,可以根据需要自定义,例如 "END" 或其他不常见的字符串。边界符不会出现在最终的输出中。
2. 嵌入变量: 在 here document 中可以插入变量:
powershell
name="John"
cat <<-EOF
Hello, $name.
EOF
输出:
powershell
Hello, John.
这样可以在多行输入中嵌入变量值。
3. 防止变量替换: 如果不希望变量在文本中被替换,可以在 delimiter 前使用单引号:
powershell
name="John"
cat <<-'EOF'
Hello, $name.
EOF
输出:
powershell
Hello, $name.
这样会确保 $name 作为字符串而不是变量被解释。
4. 缩进和空格处理: 通常,在 <<- 中使用减号 - 可以忽略行前的制表符,但不能忽略普通空格:
powershell
cat <<-EOF
This line will be correctly indented.
This line too.
EOF
5. 将多行文本提供给命令: 除了 cat 命令,here document 还可以用于将多行文本送入其他命令,如 SQL 语句的输入。
powershell
mysql -u root -p <<-EOSQL
CREATE DATABASE my_database;
USE my_database;
CREATE TABLE my_table (id INT, name VARCHAR(255));
EOSQL
这样直接在命令行或脚本中运行一系列 SQL 语句。