如何在 Shell 脚本中实现字符串的截取和拼接?(容易)

👨‍⚕️ 主页: gis分享者

👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅!

👨‍⚕️ 收录于专栏:Shell 面试

文章目录

  • 一、🍀前言
    • [1.1 ☘️字符串截取](#1.1 ☘️字符串截取)
    • [1.2 ☘️字符串拼接](#1.2 ☘️字符串拼接)
    • [1.3 ☘️知识扩展](#1.3 ☘️知识扩展)

一、🍀前言

在 Shell 脚本中,可以使用多种方法来实现字符串的截取和拼接。以下是一些常见的方法:

1.1 ☘️字符串截取

使用 Shell 内置变量:

通过 ${var:offset:length} 这种形式可以截取字符串。

powershell 复制代码
str="Hello, World!"
# 截取前5个字符
echo ${str:0:5}
# 截取从第7个字符开始的子字符串
echo ${str:6}
# 截取从第7个字符开始的5个字符
echo ${str:6:5}

使用 cut 命令:

cut 命令可以根据字符、字节或字段来截取字符串。

powershell 复制代码
# 截取前5个字符
echo "Hello, World!" | cut -c 1-5

使用 sed 命令:

sed 命令可以进行复杂的文本处理,包括截取字符串。

powershell 复制代码
# 截取前5个字符
echo "Hello, World!" | sed 's/^\(.\{5\}\).*/\1/'

使用 awk 命令:

awk 命令也可以用于截取字符串。

powershell 复制代码
# 截取前5个字符
echo "Hello, World!" | awk '{print substr($0, 1, 5)}'

1.2 ☘️字符串拼接

直接利用 Shell 的变量替换功能,通过简单的赋值操作来完成。

powershell 复制代码
str1="Hello"
str2=", World!"
new_str="$str1$str2"
echo $new_str  # 输出 "Hello, World!"

使用 printf 命令:

powershell 复制代码
str1="Hello"
str2="World"
printf "%s %s\n" "$str1" "$str2"  # 输出 "Hello World"

使用${}进行参数扩展的拼接:

powershell 复制代码
name="world"
greeting="Hello, ${name}!"
echo "$greeting"  # 输出 "Hello, world!"

使用awk进行更复杂的操作:

powershell 复制代码
str1="Hello"
str2="World"
echo | awk "{print \"$str1\" \"$str2\"}"  # 输出 "HelloWorld"(无空格)

1.3 ☘️知识扩展

字符串长度:

powershell 复制代码
str="Hello, World!"
len=${#str}
echo $len  # 输出 13

从特定字符开始截取:

powershell 复制代码
str="Hello, World!"
sub_str=${str:7}
echo $sub_str  # 输出 "World!"

从特定字符结尾开始截取:

powershell 复制代码
str="Hello, World!"
sub_str=${str: -6}
echo $sub_str  # 输出 "World!"

拼接多个字符串:

powershell 复制代码
part1="Hello"
part2=" "
part3="World"
full_str="$part1$part2$part3!"
echo $full_str  # 输出 "Hello World!"

使用命令替换进行拼接:

使用命令替换(如 $(command))来动态生成部分字符串并进行拼接。

powershell 复制代码
user=$(whoami)
date=$(date '+%Y-%m-%d')
welcome_str="Hello $user, today is $date."
echo $welcome_str  # 输出 "Hello <用户名>, today is <日期>."
相关推荐
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
前端Hardy1 天前
面试官:JS数组的常用方法有哪些?这篇总结让你面试稳了!
javascript·面试
牛奶1 天前
React 底层原理 & 新特性
前端·react.js·面试
牛奶1 天前
ts随笔:面向对象与高级类型
前端·面试·typescript
牛奶1 天前
React 基础理论 & API 使用
前端·react.js·面试
SuperEugene1 天前
从 Vue2 到 Vue3:语法差异与迁移时最容易懵的点
前端·vue.js·面试
SuperEugene2 天前
接口类型管理:从 any 到有组织的 api.d.ts
前端·面试·typescript
牛奶2 天前
ts随笔:基础与类型系统
前端·面试·typescript
用户73992986959722 天前
DeepSeek/GPT-4 落地实战:我如何用 Node.js + AI 手搓一个“面试神器”
面试