什么是Here Document

Here Document 是在Linux Shell 中的一种特殊的重定向方式,它的基本的形式如下

cmd << delimiter
Here Document Content
delimiter

它的作用就是将两个 delimiter 之间的内容(Here Document Content 部分) 传递给cmd 作为输入参数。

比如在终端中输入cat << EOF ,系统会提示继续进行输入,输入多行信息再输入EOF,中间输入的信息将会显示在屏幕上。如下:

fish@mangos:~$ cat << EOF
> First Line
> Second Line
> Third Line EOF
> EOF
First Line
Second Line
Third Line EOF

注: >这个符号是终端产生的提示输入信息的标识符

这里要注意几点

  1. EOF 只是一个标识而已,可以替换成任意的合法字符
  2. 作为结尾的delimiter一定要顶格写,前面不能有任何字符
  3. 作为结尾的delimiter后面也不能有任何的字符(包括空格)
  4. 作为起始的delimiter前后的空格会被省略掉

Here Document 不仅可以在终端上使用,在shell 文件中也可以使用,例如下面的here.sh 文件

cat << EOF > output.sh
echo "hello"
echo "world"
EOF

使用 sh here.sh 运行这个脚本文件,会得到output.sh 这个新文件,里面的内容如下

echo "hello"
echo "world"

Here Document的变形

delimiter 与变量在Here Document 的内容中,不仅可以包括普通的字符,还可以在里面使用变量,例如将上面的here.sh 改为

cat << EOF > output.sh
echo "This is output"
echo $1
EOF

使用sh here.sh HereDocument 运行脚本得到output.sh的内容

echo "This is output"
echo HereDocument

在这里 $1 被展开成为了脚本的参数 HereDocument

但是有时候不想展开这个变量怎么办呢,可以通过在起始的 delimiter的前后添加 " 来实现,例如将上面的here.sh 改为

cat << "EOF" > output.sh  #注意引号
echo "This is output"
echo $1
EOF

得到的output.sh 的内容为

echo "This is output"
echo $1

Here Document 还有一个用法就是将 '<<' 变为 '<<-'。 使用 <<- 的唯一变化就是Here Document 的内容部分每行前面的 tab (制表符)将会被删除掉,这种用法是为了编写Here Document的时候可以将内容部分进行缩进,方便阅读代码。

转自:https://my.oschina.net/u/1032146/blog/146941

最新文章

  1. [LeetCode] Course Schedule 课程清单
  2. gulp ---攻略一
  3. Daily Scrum 12.11
  4. Table of Contents - JMS
  5. Java实战之03Spring-02Spring的核心之IoC
  6. hdu 1022 Train Problem I(栈)
  7. JVM菜鸟进阶高手之路十三(等你来战!!!)
  8. 合并 CentOS 6.8 的两个ISO镜像
  9. 在Java Web项目中添加定时任务
  10. python 字符串常用操作
  11. Spring Boot 初识
  12. linux6.8安装docker
  13. stl中的for_each() 函数的注意事项
  14. 谈USB重定向的方式
  15. 《FPGA设计技巧与案例开发详解-第二版》全套资料包
  16. uni/微信小程序 - 使用外部字体
  17. js 字符串匹配
  18. BZOJ4802:欧拉函数(Pollard-Rho,欧拉函数)
  19. 【python】FTP客户端
  20. WEB测试基础

热门文章

  1. EXPLAINING AND HARNESSING ADVERSARIAL EXAMPLES
  2. iOS提交AppStore审核时:提示有其他支付并隐藏功能被拒的处理办法
  3. 基于Spring MVC + Spring + MyBatis的【野生动物保护系统】
  4. 使用 jQuery 选择器获取页面元素,然后利用 jQuery 对象的 css() 方法设置其 display 样式属性,从而实现显示和隐藏效果。
  5. IIS部署.net core项目
  6. MongoDB与微服务
  7. mysql组织结构
  8. Drupal 8 环境搭建部署
  9. linux 之 导出远程oracle数据库表结构及数据
  10. 不用find,怎样递归地给目录设置700,给文件设置600权限?