Unix Shell中单引号、双引号字符、反斜杠、反引号的使用[转]

2024-05-07 10:48

本文主要是介绍Unix Shell中单引号、双引号字符、反斜杠、反引号的使用[转],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在执行shell脚本的时候,shell将会对脚本中的行进行解释,然后执行;
对于一些特殊处理的句子,我们可以使用引号或者反斜线来避免shell解释执行之。
如下,当在命令行中输入:
echo *
child.sh env_variable father.sh param.sh profile.sh 125017.sh
默认会将当前文件夹下的所有文件都打印出来,但我们需要的是输出一个“*”。
可以以这样的方式让shell不去解释星号(*):
echo "*"
*

下面是shell引用类型
------------------------------
"" 双引号
'' 单引号
` 反引号
\ 反斜线
------------------------------
1.双引号
使用双引号,可引用除了字符$、`、\外的任意字符或字符串。
例如:
STR="MX2 is better than MI2"
echo "$STR"
MX2 is better than MI2
也可以去掉双引号:
echo $STR
MX2 is better than MI2

双引号可以使具有特殊含义的词失去其原本的意义,如下:
cal
December 2012
Sun Mon Tue Wed Thu Fri Sat
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31

但是,当我们将cal命令赋给一个变量,如下:
CALENDAR="cal"
echo $CALENDAR
cal
这里,双引号是cal命令失去了原有的显示日历的功能;这里双引号类似于转义字符。

比如DB2中,我们要将这样的字符串('1','2')添加到表的一个字段中,那么我们将怎么写呢?
db2 => select '1','2' from sysibm.sysdummy1
1 2
- -
1 2
从这里看到,db2将'1','2'认为是2个字符串,这是因为单引号在数据库中有着特殊的含义。
我们要将其转义,然后才可以添加到表中,这个起着转义字符呢就是单引号('),如下:
db2 => select ''1','2'' from sysibm.sysdummy1
SQL0104N 在 "select ''" 后面找到异常标记
"1','2''"。预期标记可能包括:"<space>"。 SQLSTATE=42601
这里除了第一个单引号和最后一个单引号对应之外,其余的都未进行转义,所以报错,
下面是正确的写法:
db2 => select '''1'',''2''' from sysibm.sysdummy1
1
-------
'1','2'

在DB2 400上也是同样的写法:
select '''1'',''2''' from qsys2/qsqptabl 
....+....1.... 
Constant value 
'1','2' 
******** End of data ********

如果在字符才中有双引号的话,可以使用反斜杠"\"来进行转义,如下:
STR="\"LENOVO"
echo "my PC is made by $STR"
my PC is made by "LENOVO
如果将$符号转义了,那么STR变量将失去意义:
echo "my PC is made by \$STR"
my PC is made by $STR

2.单引号
单引号与双引号类似,不同的是shell会忽略任何引用值,即屏蔽的单引号内的特殊字符的原本含义。
如:echo ‘my name is $LOGNAME’其结果为:my name is $LOGNAME

3.单引号和双引号的区别
单引号‘’:取消除单引号以外的任何字符的特殊含义。
如:echo ‘my name is $name’其结果为:my name is $name,此时$只作为一个普通字符使用了。 
双引号“”:取消除双引号、$号以及_号以外的所有字符的特殊含义
单引号是强引用,引号里的值是什么,变量的值就是什么;
双引号是弱引用,引号里的值若再包含变量,那在赋值的时候,所有这些变量就被立即替换了。
例如:
echo "who am i:$LOGNAME" 结果:who am i:yeexun
echo "who am i:'$LOGNAME'" 结果:who am i:'yeexun'
echo "who am i:"$LOGNAME"" 结果:who am i:yeexun

echo 'who am i:$LOGNAME' 结果:who am i:$LOGNAME
echo 'who am i:"$LOGNAME"' 结果:who am i:"$LOGNAME"
echo 'who am i:'$LOGNAME'' 结果:who am i:yeexun

4.反引号
反引号(`)用于设置系统命令输出到变量,shell认为反引号中的内容是一个系统命令,
所以将会执行之:
echo `date`
Mon Dec 24 16:06:55 CST 2012
这和直接输入date命令是一样的:
date
Mon Dec 24 16:07:12 CST 2012
若输入一个非系统命令,则shell不认识此命令,将会报错:
echo `DATE`
ksh: DATE: not found
关于date命令,参照:http://blog.csdn.net/bobo12082119/article/details/8426831

5.反斜杠
反斜杠起的作用是将一些特殊字符按原样输出,这些特殊字符有:$、*、`、+、^、&、|、"、?。
例如:echo *
将当前目录下的文件名和目录名都列出来。
echo \*
*
而使用反斜杠转义之后,就输出了星号。

分类: Shell



来源:http://www.cnblogs.com/jackluo/p/3435499.html

这篇关于Unix Shell中单引号、双引号字符、反斜杠、反引号的使用[转]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/967137

相关文章

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

C#中SortedSet的具体使用

《C#中SortedSet的具体使用》SortedSet是.NETFramework4.0引入的一个泛型集合类,它实现了一个自动排序的集合,内部使用红黑树数据结构来维护元素的有序性,下面就来介绍一下如... 目录基础概念主要特性创建和初始化基本创建方式自定义比较器基本操作添加和删除元素查询操作范围查询集合运

C# Opacity 不透明度的具体使用

《C#Opacity不透明度的具体使用》本文主要介绍了C#Opacity不透明度的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录WinFormsOpacity以下是一些使用Opacity属性的示例:设置窗体的透明度:设置按钮的透

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结

Spring Integration Redis 使用示例详解

《SpringIntegrationRedis使用示例详解》本文给大家介绍SpringIntegrationRedis的配置与使用,涵盖依赖添加、Redis连接设置、分布式锁实现、消息通道配置及... 目录一、依赖配置1.1 Maven 依赖1.2 Gradle 依赖二、Redis 连接配置2.1 配置 R

Python WSGI HTTP服务器Gunicorn使用详解

《PythonWSGIHTTP服务器Gunicorn使用详解》Gunicorn是Python的WSGI服务器,用于部署Flask/Django应用,性能高且稳定,支持多Worker类型与配置,可处... 目录一、什么是 Gunicorn?二、为什么需要Gunicorn?三、安装Gunicorn四、基本使用启

MySQL 临时表创建与使用详细说明

《MySQL临时表创建与使用详细说明》MySQL临时表是存储在内存或磁盘的临时数据表,会话结束时自动销毁,适合存储中间计算结果或临时数据集,其名称以#开头(如#TempTable),本文给大家介绍M... 目录mysql 临时表详细说明1.定义2.核心特性3.创建与使用4.典型应用场景5.生命周期管理6.注

python urllib模块使用操作方法

《pythonurllib模块使用操作方法》Python提供了多个库用于处理URL,常用的有urllib、requests和urlparse(Python3中为urllib.parse),下面是这些... 目录URL 处理库urllib 模块requests 库urlparse 和 urljoin编码和解码

使用Python提取PDF大纲(书签)的完整指南

《使用Python提取PDF大纲(书签)的完整指南》PDF大纲(Outline)​​是PDF文档中的导航结构,通常显示在阅读器的侧边栏中,方便用户快速跳转到文档的不同部分,大纲通常以层级结构组织,包含... 目录一、PDF大纲简介二、准备工作所需工具常见安装问题三、代码实现完整代码核心功能解析四、使用效果控