news 2026/2/25 4:45:01

shell脚本-read-输入

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
shell脚本-read-输入

1.基础

最简单的用法是不带任何参数,直接读取用户输入,默认存入内置变量REPLY中。

#!/bin/bashecho"请输入一段话:"read# 等待用户输入echo"你输入的是:$REPLY"

2. 带提示符与变量赋值

实际开发中,我们通常会指定变量名来存储输入,并使用-p选项直接显示提示信息,这样比先用echo打印提示更简洁。

#!/bin/bashread-p"请输入你的名字: "nameread-p"请输入你的年龄: "ageecho"你好,$name!你今年$age岁。"

3. 静默输入(适合密码)

需要输入密码等敏感信息,不希望屏幕显示输入内容,可以使用-s选项。

#!/bin/bashread-sp"请输入密码: "passwdecho# 这里加一个换行,否则光标会紧跟在密码后面echo"密码已输入完毕(为了安全,这里不显示明文)"

4. 限制输入时间与字符数

场景 A:限时回答使用-t选项可以设置等待时间(秒)。如果用户在规定时间内没有输入,脚本会自动继续执行。

#!/bin/bashifread-t3-p"请在3秒内回答 (y/n): "answer;thenecho"你的选择是:$answer"elseecho"时间到,已默认选择否。"fi

场景 B:只读取特定字符使用-n选项可以限制读取的字符数量。例如,只需要用户按一个键来确认。

#!/bin/bashread-n1 -p"是否继续?(y/n): "choiceecho# 换行if["$choice"="y"];thenecho"继续执行..."elseecho"操作取消。"fi

5. 高级用法:数组与分隔符

场景 A:读取为数组如果你希望用户输入一串用空格分隔的内容(如多个文件名),可以使用-a将其存入数组。

#!/bin/bashread-a file_list -p"请输入要处理的文件名(空格分隔): "echo"你选择了${#file_list[@]}个文件:"forfilein"${file_list[@]}";doecho" -$file"done

场景 B:自定义结束符默认情况下,read遇到回车键(换行符)才结束。使用-d可以指定其他字符作为结束标志。例如,以#号结束输入。

#!/bin/bashread-d'#'-p"请输入文本(以 # 号结束输入): "contentechoecho"你输入的内容是:$content"

总结:常用选项

选项作用典型场景
-p "提示"显示提示信息通用的输入交互
-s静默输入(不回显)输入密码、密钥
-t 5设置超时时间(秒)防止脚本长时间挂起
-n 1限制读取字符数简单的 yes/no 选择
-a arr将输入存入数组批量处理多个参数
-r原始模式(不转义\输入包含路径或特殊符号

特别提示:读取文件

除了读取键盘,read还常用于逐行读取文件。通常结合while循环使用,这是处理文本文件(如配置文件)的常用技巧:

# 读取文件内容whilereadline;doecho"处理行:$line"done<filename.txt
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/22 17:19:17

EmotiVoice生成语音能否通过平台原创审核?

EmotiVoice生成语音能否通过平台原创审核&#xff1f; 在短视频、播客和有声书内容爆炸式增长的今天&#xff0c;创作者们正面临一个共同难题&#xff1a;如何高效产出高质量音频内容&#xff0c;同时又能通过平台严苛的“原创性审核”&#xff1f;越来越多的人开始尝试使用AI语…

作者头像 李华
网站建设 2026/2/23 15:30:35

婚庆公司引入EmotiVoice制作新人告白

婚庆公司引入EmotiVoice制作新人告白 在婚礼视频的剪辑间里&#xff0c;一段“告白”正在被反复调试。导演皱着眉头&#xff1a;“这配音太机械了&#xff0c;像是AI念稿。”一旁的客户也摇头&#xff1a;“声音不像我&#xff0c;感情也不对&#xff0c;听起来不走心。”这样的…

作者头像 李华
网站建设 2026/2/23 15:43:39

EmotiVoice支持自定义情感标签训练,拓展应用场景

EmotiVoice支持自定义情感标签训练&#xff0c;拓展应用场景 在虚拟主播直播带货时突然切换成“愤怒”语气推销产品&#xff0c;或是客服机器人用“温柔安抚”模式化解用户投诉——这些曾经只存在于科幻电影中的场景&#xff0c;正随着情感语音合成技术的突破逐渐成为现实。传统…

作者头像 李华
网站建设 2026/2/22 23:20:24

JupyterHub配置实战:从零到精通的5个关键步骤

JupyterHub配置实战&#xff1a;从零到精通的5个关键步骤 【免费下载链接】jupyterhub Multi-user server for Jupyter notebooks 项目地址: https://gitcode.com/gh_mirrors/ju/jupyterhub JupyterHub作为强大的多用户环境管理平台&#xff0c;其配置过程决定了系统的性…

作者头像 李华
网站建设 2026/2/21 16:14:00

EmotiVoice语音在车载环境中的清晰度表现

EmotiVoice语音在车载环境中的清晰度表现 在高速行驶的车内&#xff0c;驾驶员需要一边关注路况&#xff0c;一边处理来自导航、车辆状态和娱乐系统的多重信息。此时&#xff0c;语音作为最安全的人机交互通道&#xff0c;其清晰度与表达力直接决定了交互效率甚至行车安全。然而…

作者头像 李华
网站建设 2026/2/22 14:12:12

电商商品介绍视频自动生成流水线

电商商品介绍视频自动生成流水线中的多情感语音合成技术解析 在今天的电商战场上&#xff0c;一个爆款视频可能只需要几秒钟就能抓住用户注意力。而在这短短几十秒里&#xff0c;决定用户是否停留的关键&#xff0c;往往不只是画面——声音的情绪张力、语调的亲和力&#xff0c…

作者头像 李华