当前位置: 首页 > article >正文

Shell编程核心符号与格式化操作详解

Shell编程作为Linux系统管理和自动化运维的核心技能,掌握其常用符号和格式化操作是提升脚本开发效率的关键。本文将深入解析Shell中重定向、管道符、EOF、输入输出格式化等核心概念,并通过丰富的实践案例帮助读者掌握这些重要技能。

一、信息传递与重定向操作

在Shell脚本中,信息的传递和重定向是最基础也最常用的操作,它们让命令之间能够高效地交互数据,并将结果保存到指定位置。

重定向符号详解

重定向操作主要分为覆盖式和追加式两种,每种类型都有其特定的使用场景:

  • 覆盖式重定向:使用><符号,会将目标文件的原有内容清空后再写入新内容
  • 追加式重定向:使用>><<符号,会在目标文件的末尾添加新内容而不影响原有数据

下面是一个完整的重定向操作演示:

# 查看原始文件内容
[root@localhost ~]# cat message.txt
Hello World!# 覆盖式重定向:清空文件并写入新内容
[root@localhost ~]# echo "New Content" > message.txt
[root@localhost ~]# cat message.txt
New Content# 追加式重定向:在文件末尾添加内容
[root@localhost ~]# echo "Appended Line" >> message.txt
[root@localhost ~]# cat message.txt
New Content
Appended Line

管道符的强大作用

管道符|是Shell中实现命令间数据传递的重要机制,它可以将前一个命令的输出作为后一个命令的输入,形成强大的命令组合:

# 查找系统中所有包含"httpd"的进程
[root@localhost ~]# ps aux | grep httpd# 统计当前目录下文件数量
[root@localhost ~]# ls -la | wc -l# 过滤环境变量中包含"PATH"的项
[root@localhost ~]# env | grep PATH
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

二、终端输出控制与后台执行

在Shell脚本执行过程中,合理控制输出和执行方式可以提升脚本的使用体验和效率。

后台执行与作业控制

使用&符号可以将命令放到后台执行,避免前台阻塞:

# 前台执行长时间运行的命令会阻塞终端
[root@localhost ~]# sleep 10
# 终端会等待10秒后才返回# 后台执行命令,终端立即返回
[root@localhost ~]# sleep 10 &
[1] 12345# 查看后台作业
[root@localhost ~]# jobs
[1]+  Running                 sleep 10 &# 终止后台作业
[root@localhost ~]# kill %1

输出信息分类与重定向

Shell将输出信息分为三类:

  • 1:标准正确输出
  • 2:标准错误输出
  • &:所有输出

下面是一个完整的输出重定向案例:

# 创建测试脚本
[root@localhost ~]# cat test.sh
#!/bin/bash
echo "这是正确输出"
non_existent_command  # 这是一个错误命令
echo "另一条正确输出"# 执行脚本并分别重定向正确和错误输出
[root@localhost ~]# ./test.sh 1>correct.txt 2>error.txt# 查看重定向结果
[root@localhost ~]# cat correct.txt
这是正确输出
另一条正确输出[root@localhost ~]# cat error.txt
test.sh:行3: non_existent_command: 未找到命令

三、EOF与文本输入格式化

在Shell脚本中,处理多行文本输入和格式化内容是常见需求,EOF机制为此提供了优雅的解决方案。

EOF原理与使用场景

EOF(End Of File)是一种分界符机制,用于标记多行输入的开始和结束:

# 直接在终端使用EOF输入多行内容
[root@localhost ~]# cat << EOF
> 这是一个多行文本
> 可以包含任意格式
> 包括空格和缩进
> EOF# 将EOF内容写入文件
[root@localhost ~]# cat > config.txt << EOF
> server {
>     listen 80;
>     server_name example.com;
>     location / {
>         proxy_pass http://backend;
>     }
> }
> EOF

EOF的高级用法

EOF机制支持自定义分界符和缩进处理:

# 使用自定义分界符
[root@localhost ~]# cat << MARKER
> 这是使用MARKER作为分界符的内容
> 可以包含任何文本
> MARKER# 处理缩进的EOF(使用<<-)
[root@localhost ~]# cat <<- EOF
>     这是一个缩进的文本
>     缩进会被自动去除
> EOF

四、输入输出格式化技巧

echo命令的高级用法

echo命令不仅可以输出文本,还支持丰富的格式化选项:

# 输出带颜色的文本
echo -e "\033[31m红色文本\033[0m"
echo -e "\033[32m绿色文本\033[0m"
echo -e "\033[33m黄色文本\033[0m"# 输出带背景色的文本
echo -e "\033[41;37m红底白字\033[0m"
echo -e "\033[42;37m绿底白字\033[0m"# 输出带格式的文本(下划线、加粗)
echo -e "\033[4m下划线文本\033[0m"
echo -e "\033[1m加粗文本\033[0m"

printf的强大格式化能力

printf命令提供了类似C语言的格式化输出功能,支持更复杂的格式控制:

# 基本格式化输出
printf "姓名: %s, 年龄: %d\n" "张三" 25# 数字格式化(保留两位小数)
printf "价格: %.2f\n" 19.995# 字段宽度控制
printf "|%10s|%10s|\n" "姓名" "年龄"
printf "|%10s|%10d|\n" "张三" 25
printf "|%10s|%10d|\n" "李四" 30# 数字填充
printf "编号: %05d\n" 123

五、实战案例:自动部署脚本

下面是一个综合运用上述知识的Java环境自动部署脚本:

#!/bin/bash
# Java环境自动部署脚本
# 版本:v1.0
# 作者:doubao
# 日期:2025-06-06# 定义颜色变量
RED="\033[31m"
GREEN="\033[32m"
YELLOW="\033[33m"
RESET="\033[0m"# 定义安装路径和软件包
SOFTWARE_DIR="/data/softs"
INSTALL_DIR="/data/server"
JAVA_PACKAGE="jdk-8u301-linux-x64.tar.gz"
JAVA_DIR="jdk1.8.0_301"
JAVA_LINK="java"# 输出欢迎信息
echo -e "${GREEN}====================================${RESET}"
echo -e "${GREEN}       Java环境自动部署脚本         ${RESET}"
echo -e "${GREEN}====================================${RESET}"
echo -e "${YELLOW}即将开始安装Java环境,请确认以下信息:${RESET}"
echo -e "软件包路径: ${SOFTWARE_DIR}/${JAVA_PACKAGE}"
echo -e "安装目录: ${INSTALL_DIR}"
echo -e "${YELLOW}====================================${RESET}"# 确认是否继续安装
read -p "是否继续安装? (y/n): " CONFIRM
if [ "$CONFIRM" != "y" ] && [ "$CONFIRM" != "Y" ]; thenecho -e "${RED}安装已取消${RESET}"exit 1
fi# 检查软件包是否存在
if [ ! -f "$SOFTWARE_DIR/$JAVA_PACKAGE" ]; thenecho -e "${RED}错误: 软件包 $SOFTWARE_DIR/$JAVA_PACKAGE 不存在${RESET}"exit 1
fi# 创建安装目录
mkdir -p "$INSTALL_DIR"
echo -e "${GREEN}已创建安装目录: $INSTALL_DIR${RESET}"# 解压软件包
echo -e "${YELLOW}正在解压软件包...${RESET}"
tar -xzf "$SOFTWARE_DIR/$JAVA_PACKAGE" -C "$INSTALL_DIR"
echo -e "${GREEN}软件包解压完成${RESET}"# 创建符号链接
ln -sf "$INSTALL_DIR/$JAVA_DIR" "$INSTALL_DIR/$JAVA_LINK"
echo -e "${GREEN}已创建符号链接: $INSTALL_DIR/$JAVA_LINK${RESET}"# 配置环境变量
echo -e "${YELLOW}正在配置环境变量...${RESET}"
cat > /etc/profile.d/java.sh << EOF
export JAVA_HOME=$INSTALL_DIR/$JAVA_LINK
export PATH=\$JAVA_HOME/bin:\$PATH
EOF# 生效环境变量
source /etc/profile.d/java.sh
echo -e "${GREEN}环境变量配置完成${RESET}"# 检查安装结果
echo -e "${YELLOW}正在检查Java安装...${RESET}"
java -version 2>&1 | tee /tmp/java_install.log
JAVA_VERSION=$(grep "version" /tmp/java_install.log | awk -F\" '{print $2}')# 输出安装结果
echo -e "${GREEN}====================================${RESET}"
echo -e "${GREEN}         安装结果总结           ${RESET}"
echo -e "${GREEN}====================================${RESET}"
echo -e "Java安装目录: ${INSTALL_DIR}/${JAVA_LINK}"
echo -e "Java版本: ${GREEN}$JAVA_VERSION${RESET}"
echo -e "${GREEN}====================================${RESET}"
echo -e "${GREEN}Java环境安装成功!${RESET}"

总结

Shell编程中的符号和格式化操作是提升脚本质量和效率的关键。本文详细介绍了重定向、管道符、EOF、输入输出格式化等核心概念,并通过丰富的案例展示了它们的实际应用。掌握这些技能后,你将能够编写更专业、更高效的Shell脚本,轻松应对各种系统管理和自动化运维任务。

相关文章:

Shell编程核心符号与格式化操作详解

Shell编程作为Linux系统管理和自动化运维的核心技能&#xff0c;掌握其常用符号和格式化操作是提升脚本开发效率的关键。本文将深入解析Shell中重定向、管道符、EOF、输入输出格式化等核心概念&#xff0c;并通过丰富的实践案例帮助读者掌握这些重要技能。 一、信息传递与重定…...

针对“仅某个地区出现Bug”的原因分析与解决方案

一、核心排查方向&#xff08;按优先级排序&#xff09; 地区相关配置差异 检查点&#xff1a; 该地区是否有独立的配置文件或数据库分片&#xff1f;是否启用了地区特定的功能开关&#xff08;Feature Flag&#xff09;或AB测试&#xff1f;本地化内容&#xff08;如语言、时…...

学习STC51单片机30(芯片为STC89C52RCRC)

每日一言 当你感到疲惫时&#xff0c;正是成长的关键时刻&#xff0c;再坚持一下。 IIC协议 是的&#xff0c;IIC协议就是与我们之前的串口通信协议是同一个性质&#xff0c;就是为了满足模块的通信&#xff0c;其实之前的串口通信协议叫做UART协议&#xff0c;我们千万不要弄…...

sql中group by使用场景

GROUP BY语句在SQL中用于将多个记录分组为较小的记录集合&#xff0c;以便对每个组执行聚合函数&#xff0c;如COUNT(), MAX(), MIN(), SUM(), AVG()等。GROUP BY的使用场景非常广泛&#xff0c;以下是一些典型的应用场景&#xff1a; 统计数量 当你想要计算某个字段的唯一值数…...

将HTML内容转换为Canvas图像,主流方法有效防止文本复制

HTML to Canvas 使用说明 项目概述 此项目实现了将HTML内容转换为Canvas图像的功能&#xff0c;可有效防止文本被复制。适用于需要保护内容的场景&#xff0c;如试题系统、付费内容等。 主要功能 防止复制: 将文本内容转换为Canvas图像&#xff0c;使用户无法选择和复制Mat…...

Python-进程

进程 简介 操作系统分配资源的基本单位 创建 依赖 依赖模块 multiprocessing 中的 Process 语法 Process(group[,target[,name[,args[,kwargs]]]]) target&#xff1a;如果传递了函数的引用&#xff0c;这个子进程就执行这里的代码args&#xff1a;元组的方式传递&#x…...

Paraformer分角色语音识别-中文-通用 FunASR demo测试与训练

文章目录 0 资料1 Paraformer分角色语音识别-中文-通用1 模型下载2 音频识别测试3 FunASR安装 &#xff08;训练用&#xff09;4 训练 0 资料 https://github.com/modelscope/FunASR/blob/main/README_zh.md https://github.com/modelscope/FunASR/blob/main/model_zoo/readm…...

【从0-1的CSS】第1篇:CSS简介,选择器以及常用样式

文章目录 CSS简介CSS的语法规则选择器id选择器元素选择器类选择器选择器优先级 CSS注释 CSS常用设置样式颜色颜色名称(常用)RGB(常用)RGBA(常用)HEX(常用)HSLHSLA 背景background-colorbackground-imagebackground-size 字体text-aligntext-decorationtext-indentline-height 边…...

对抗反爬机制的分布式爬虫自适应策略:基于强化学习的攻防博弈建模

在大数据时代&#xff0c;数据的价值不言而喻。网络爬虫作为获取数据的重要工具&#xff0c;被广泛应用于各个领域。然而&#xff0c;随着爬虫技术的普及&#xff0c;网站为了保护自身数据安全和服务器性能&#xff0c;纷纷采取了各种反爬机制。这就使得爬虫与反爬虫之间形成了…...

JDK21深度解密 Day 15:JDK21实战最佳实践总结

【JDK21深度解密 Day 15】JDK21实战最佳实践总结 文章简述 本篇文章是《JDK21深度解密:从新特性到生产实践的全栈指南》系列的第15篇,聚焦于JDK21实战最佳实践总结。作为Java历史上最重要的LTS版本之一,JDK21带来了虚拟线程、结构化并发、模式匹配、ZGC优化等革命性特性,…...

手写muduo网络库(一):项目构建和时间戳、日志库

引言 本文作为手写 muduo 网络库系列开篇&#xff0c;聚焦项目基础框架搭建与核心基础工具模块设计。通过解析 CMake 工程结构设计、目录规划原则&#xff0c;结合时间戳与日志系统的架构&#xff0c;为后续网络库开发奠定工程化基础。文中附完整 CMake 配置示例及模块代码。 …...

每日算法刷题Day25 6.7:leetcode二分答案3道题,用时1h40min(遇到两道动态规划和贪心时间较长)

3. 1631.最小体力消耗路径(中等,dfs不熟练) 1631. 最小体力消耗路径 - 力扣&#xff08;LeetCode&#xff09; 思想 1.你准备参加一场远足活动。给你一个二维 rows x columns 的地图 heights &#xff0c;其中 heights[row][col] 表示格子 (row, col) 的高度。一开始你在最左…...

14-Oracle 23ai Vector Search 向量索引和混合索引-实操

一、Oracle 23ai支持的2种主要的向量索引类型&#xff1a; 1.1 内存中的邻居图向量索引 (In-Memory Neighbor Graph Vector Index) HNSW(Hierarchical Navigable Small World &#xff1a;分层可导航小世界)索引 是 Oracle AI Vector Search 中唯一支持的内存邻居图向量索引类…...

kubeadm安装k8s

1、环境准备 1.1、升级系统内核 参考另一篇文章&#xff1a;https://blog.csdn.net/u012533920/article/details/148457715?spm1011.2415.3001.5331 1.2、设置Hostname cat <<EOF > /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhos…...

服务器新建用户无法使用conda

服务器新建用户无法使用conda 1.将.bashrc文件复制到新用户家目录下 sudo cp .bashrc /home/newuser/.bashrc2.source命令激活该文件 source ~/.bashrc3.将.condarc文件复制到新用户家目录下 sudo cp .condarc/home/newuser/.condarc...

Web前端基础:JavaScript

1.JS核心语法 1.1 JS引入方式 第一种方式&#xff1a;内部脚本&#xff0c;将JS代码定义在HTML页面中 JavaScript代码必须位于<script></script>标签之间在HTML文档中&#xff0c;可以在任意地方&#xff0c;放置任意数量的<script></script>一般会把…...

基于对比学习的带钢表面缺陷分类研究,整合SimCLR自监督预训练与YOLOv8目标检测框架的技术解析及Python实现方案

以下基于对比学习的带钢表面缺陷分类研究,整合SimCLR自监督预训练与YOLOv8目标检测框架的技术解析及Python实现方案: 基于对比学习的带钢表面缺陷分类研究 ——SimCLR与YOLOv8算法融合应用 #mermaid-svg-VqDPIOfR5WJcGtD7 {font-family:"trebuchet ms",verdana,ar…...

基于AWS Serverless架构:零运维构建自动化SEO内容生成系统

作者&#xff1a;[Allen] 技术专栏 | 深度解析云原生SEO自动化 在流量为王的时代&#xff0c;持续产出高质量SEO内容成为技术运营的核心痛点。传统方案面临开发成本高、扩展性差、关键词响应滞后三大难题。本文将分享如何用AWS Serverless技术栈&#xff0c;构建一套零服务器运…...

【.net core】天地图坐标转换为高德地图坐标(WGS84 坐标转 GCJ02 坐标)

类文件 public static class WGS84ToGCJ02Helper {// 定义一些常量private const double PI 3.14159265358979324;private const double A 6378245.0;private const double EE 0.00669342162296594323;// 判断坐标是否在中国范围内&#xff08;不在国内则不进行转换&#x…...

Linux操作系统故障应急场景及对应排查方法

001&#xff1a;系统CPU负载高并触发监控报警 005 查看系统CPU使用情况,&#xff0c;确认CPU数量&#xff0c;确认系统负载&#xff0c;确认CPU高对系统的影响 006 定位占用CPU资源最多的进程&#xff0c;根据进程判断是应用进程还是系统进程还是第三方工具进程。 014 查看…...

电镀机的阳极是什么材质?

知识星球&#xff08;星球名&#xff1a;芯片制造与封测技术社区&#xff0c;点击加入&#xff09;里的学员问&#xff1a;电镀的阳极有什么讲究&#xff1f;什么是可溶性阳极和非可溶性阳极&#xff1f; 什么是可溶性阳极与非可溶性阳极&#xff1f; 可溶性阳极 阳极本身就是…...

vscode调试deepspeed的方法之一(无需调整脚本)

现在deepspeed的脚本文件是&#xff1a; # 因为使用 RTX 4000 系列显卡时&#xff0c;不支持通过 P2P 或 IB 实现更快的通信宽带&#xff0c;需要设置以下两个环境变量 # 禁用 NCCL 的 P2P 通信&#xff0c;以避免可能出现的兼容性问题 export NCCL_P2P_DISABLE"1" …...

神经网络-Day44

import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms from torch.utils.data import DataLoader import matplotlib.pyplot as plt# 设置中文字体支持 plt.rcParams["font.family"] ["SimHei"…...

创客匠人:如何通过精准定位实现创始人IP打造与知识变现

在当今知识经济时代&#xff0c;越来越多的专业人士希望通过个人品牌实现知识变现&#xff0c;但许多人面临一个共同困境&#xff1a;明明很努力&#xff0c;却收效甚微。创客匠人作为深耕知识付费赛道9年的专业机构&#xff0c;揭示了这一现象背后的关键原因——90%的IP失败源…...

Codeforces Round 509 (Div. 2) C. Coffee Break

题目大意&#xff1a; 给你n、m、d n为元素个数,m为数列长度,d为每个元素之间的最短间隔 问最少需要多少个数列可以使得元素都能装进数列&#xff0c;并且满足每个元素之间的间隔大于等于d 核心思想 使用贪心的思想&#xff0c;将元素的大小进行排序&#xff0c;问题出在必…...

榕壹云健身预约系统:多门店管理的数字化解决方案(ThinkPHP+MySQL+UniApp实现)

随着全民健身热潮的兴起&#xff0c;传统健身房在会员管理、课程预约、多门店运营等方面面临诸多挑战。针对这一需求&#xff0c;我们开发了一款基于ThinkPHPMySQLUniApp的榕壹云健身预约系统&#xff0c;为中小型健身机构及连锁品牌提供高效、灵活的数字化管理工具。本文将详细…...

QUIC——UDP实现可靠性传输

首先我们要知道TCP存在什么样的痛点问题 TCP的升级很困难TCP建立连接的延迟网络迁移需要重新建立连接TCP存在队头阻塞问题 QUIC就是为了解决以上的问题而诞生了, 下面我会介绍QUIC的一些特性和原理 QUIC对比TCP优势: 握手建连更快 QUIC内部包含了TLS, 它在自己的帧会携带TL…...

提高Python编程效率的工具推荐

在 Python 开发中&#xff0c;选择合适的工具可以显著提升编程效率。以下是一些经过精心挑选的工具&#xff0c;涵盖代码编辑、调试、数据分析等多个方面&#xff0c;希望能帮助你在 Python 开发中事半功倍。 一、集成开发环境&#xff08;IDE&#xff09; 1. PyCharm PyCha…...

React Native图片预加载:让你的应用图片预览像德芙一样丝滑

写在前面:一张图片引发的性能血案 你有没有遇到过这种情况?——用户疯狂滑动你的React Native图片列表,结果图片加载慢得像蜗牛,甚至出现空白闪烁?等到图片终于加载出来,用户早就失去耐心,愤然退出…… 但你知道吗?这个问题只需要几行代码就能解决! 比如,使用reac…...

快速上手shell脚本运行流程控制

一、条件运行流程控制 1.if单分支结构 #!/bin/bash if [ 条件 ] then动作1动作2... fi 2.if双分支结构 ​ #!/bin/bash if [ 条件 ] then动作1动作2... else动作1动作2... fi​ 3.if多分支结构 二、循环运行流程控制 1.无判定for循环 给网卡一键添加5个IP 2.判断循环 while…...