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系统管理和自动化运维的核心技能,掌握其常用符号和格式化操作是提升脚本开发效率的关键。本文将深入解析Shell中重定向、管道符、EOF、输入输出格式化等核心概念,并通过丰富的实践案例帮助读者掌握这些重要技能。 一、信息传递与重定…...
针对“仅某个地区出现Bug”的原因分析与解决方案
一、核心排查方向(按优先级排序) 地区相关配置差异 检查点: 该地区是否有独立的配置文件或数据库分片?是否启用了地区特定的功能开关(Feature Flag)或AB测试?本地化内容(如语言、时…...

学习STC51单片机30(芯片为STC89C52RCRC)
每日一言 当你感到疲惫时,正是成长的关键时刻,再坚持一下。 IIC协议 是的,IIC协议就是与我们之前的串口通信协议是同一个性质,就是为了满足模块的通信,其实之前的串口通信协议叫做UART协议,我们千万不要弄…...
sql中group by使用场景
GROUP BY语句在SQL中用于将多个记录分组为较小的记录集合,以便对每个组执行聚合函数,如COUNT(), MAX(), MIN(), SUM(), AVG()等。GROUP BY的使用场景非常广泛,以下是一些典型的应用场景: 统计数量 当你想要计算某个字段的唯一值数…...
将HTML内容转换为Canvas图像,主流方法有效防止文本复制
HTML to Canvas 使用说明 项目概述 此项目实现了将HTML内容转换为Canvas图像的功能,可有效防止文本被复制。适用于需要保护内容的场景,如试题系统、付费内容等。 主要功能 防止复制: 将文本内容转换为Canvas图像,使用户无法选择和复制Mat…...

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

Paraformer分角色语音识别-中文-通用 FunASR demo测试与训练
文章目录 0 资料1 Paraformer分角色语音识别-中文-通用1 模型下载2 音频识别测试3 FunASR安装 (训练用)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 边…...

对抗反爬机制的分布式爬虫自适应策略:基于强化学习的攻防博弈建模
在大数据时代,数据的价值不言而喻。网络爬虫作为获取数据的重要工具,被广泛应用于各个领域。然而,随着爬虫技术的普及,网站为了保护自身数据安全和服务器性能,纷纷采取了各种反爬机制。这就使得爬虫与反爬虫之间形成了…...
JDK21深度解密 Day 15:JDK21实战最佳实践总结
【JDK21深度解密 Day 15】JDK21实战最佳实践总结 文章简述 本篇文章是《JDK21深度解密:从新特性到生产实践的全栈指南》系列的第15篇,聚焦于JDK21实战最佳实践总结。作为Java历史上最重要的LTS版本之一,JDK21带来了虚拟线程、结构化并发、模式匹配、ZGC优化等革命性特性,…...

手写muduo网络库(一):项目构建和时间戳、日志库
引言 本文作为手写 muduo 网络库系列开篇,聚焦项目基础框架搭建与核心基础工具模块设计。通过解析 CMake 工程结构设计、目录规划原则,结合时间戳与日志系统的架构,为后续网络库开发奠定工程化基础。文中附完整 CMake 配置示例及模块代码。 …...
每日算法刷题Day25 6.7:leetcode二分答案3道题,用时1h40min(遇到两道动态规划和贪心时间较长)
3. 1631.最小体力消耗路径(中等,dfs不熟练) 1631. 最小体力消耗路径 - 力扣(LeetCode) 思想 1.你准备参加一场远足活动。给你一个二维 rows x columns 的地图 heights ,其中 heights[row][col] 表示格子 (row, col) 的高度。一开始你在最左…...

14-Oracle 23ai Vector Search 向量索引和混合索引-实操
一、Oracle 23ai支持的2种主要的向量索引类型: 1.1 内存中的邻居图向量索引 (In-Memory Neighbor Graph Vector Index) HNSW(Hierarchical Navigable Small World :分层可导航小世界)索引 是 Oracle AI Vector Search 中唯一支持的内存邻居图向量索引类…...
kubeadm安装k8s
1、环境准备 1.1、升级系统内核 参考另一篇文章: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引入方式 第一种方式:内部脚本,将JS代码定义在HTML页面中 JavaScript代码必须位于<script></script>标签之间在HTML文档中,可以在任意地方,放置任意数量的<script></script>一般会把…...
基于对比学习的带钢表面缺陷分类研究,整合SimCLR自监督预训练与YOLOv8目标检测框架的技术解析及Python实现方案
以下基于对比学习的带钢表面缺陷分类研究,整合SimCLR自监督预训练与YOLOv8目标检测框架的技术解析及Python实现方案: 基于对比学习的带钢表面缺陷分类研究 ——SimCLR与YOLOv8算法融合应用 #mermaid-svg-VqDPIOfR5WJcGtD7 {font-family:"trebuchet ms",verdana,ar…...

基于AWS Serverless架构:零运维构建自动化SEO内容生成系统
作者:[Allen] 技术专栏 | 深度解析云原生SEO自动化 在流量为王的时代,持续产出高质量SEO内容成为技术运营的核心痛点。传统方案面临开发成本高、扩展性差、关键词响应滞后三大难题。本文将分享如何用AWS Serverless技术栈,构建一套零服务器运…...
【.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;// 判断坐标是否在中国范围内(不在国内则不进行转换&#x…...
Linux操作系统故障应急场景及对应排查方法
001:系统CPU负载高并触发监控报警 005 查看系统CPU使用情况,,确认CPU数量,确认系统负载,确认CPU高对系统的影响 006 定位占用CPU资源最多的进程,根据进程判断是应用进程还是系统进程还是第三方工具进程。 014 查看…...

电镀机的阳极是什么材质?
知识星球(星球名:芯片制造与封测技术社区,点击加入)里的学员问:电镀的阳极有什么讲究?什么是可溶性阳极和非可溶性阳极? 什么是可溶性阳极与非可溶性阳极? 可溶性阳极 阳极本身就是…...

vscode调试deepspeed的方法之一(无需调整脚本)
现在deepspeed的脚本文件是: # 因为使用 RTX 4000 系列显卡时,不支持通过 P2P 或 IB 实现更快的通信宽带,需要设置以下两个环境变量 # 禁用 NCCL 的 P2P 通信,以避免可能出现的兼容性问题 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打造与知识变现
在当今知识经济时代,越来越多的专业人士希望通过个人品牌实现知识变现,但许多人面临一个共同困境:明明很努力,却收效甚微。创客匠人作为深耕知识付费赛道9年的专业机构,揭示了这一现象背后的关键原因——90%的IP失败源…...

Codeforces Round 509 (Div. 2) C. Coffee Break
题目大意: 给你n、m、d n为元素个数,m为数列长度,d为每个元素之间的最短间隔 问最少需要多少个数列可以使得元素都能装进数列,并且满足每个元素之间的间隔大于等于d 核心思想 使用贪心的思想,将元素的大小进行排序,问题出在必…...

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

QUIC——UDP实现可靠性传输
首先我们要知道TCP存在什么样的痛点问题 TCP的升级很困难TCP建立连接的延迟网络迁移需要重新建立连接TCP存在队头阻塞问题 QUIC就是为了解决以上的问题而诞生了, 下面我会介绍QUIC的一些特性和原理 QUIC对比TCP优势: 握手建连更快 QUIC内部包含了TLS, 它在自己的帧会携带TL…...
提高Python编程效率的工具推荐
在 Python 开发中,选择合适的工具可以显著提升编程效率。以下是一些经过精心挑选的工具,涵盖代码编辑、调试、数据分析等多个方面,希望能帮助你在 Python 开发中事半功倍。 一、集成开发环境(IDE) 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…...