Linux/UNIX不同shell环境下数组的处理

简介:
有遗漏和不当的地方请大家指正,谢谢!
[关于声明]

比较通用的做法,如ksh和bash
declare -a 数组名
注意在ksh下还支持另外一种独特的变量声明赋值语法比较特殊。

set -A varname var1 var2 var3 varn
末了要说明一下,一般任意的shell下变量可以拿来就用,不必声明。
[关于赋值]
下面的两种这种方法适用于bash和ksh。
定义一
varname=(var1 var2 var3 varn)
定义二
varname[0]=var1
varname[1]=var2
varname[2]=var3
varname[n-1]=varn
定义三
在csh我们需要这样定义:
set varname=(var1 var2 var3 varn)
set varname[1]=var1
set varname[2]=var2
set varname[3]=var3
set varname[n]=varn
特别注意在csh和其它shell中不同的是数组的下标是从1开始的。
[关于引用]
全部引用
方法一

适用于bash、ksh、csh等大部分shell。
${varname[*]}
方法二
只适用于bash、ksh,对于csh不适用。
${varname[@]}
方法三
只适用于csh,不支持ksh和bash。
$varname
单独引用
语法适用于bash、ksh、csh等大部分shell,但是在csh/tcsh下的意义和其它shell有差异。
${varname[n]}
例如:echo ${barname[3]}
请严格区分csh与bashcsh的区别。因为在csh中没有下标为0的数组元素,下标的序数是从1开始的。

数组包含数值的数目
方法一:
只适用于bash和ksh,不支持csh。
${#varname[*]}
方法二:
只支持csh,不支持bash和ksh。
$#varname

数组中某一个值的字符长度
只适用于bash和ksh,不支持csh。
${#varname[1]}


在bash、ksh下 $varname与${varname[0]}的含意是一样的; $varname[1]与${varname[1]}含意是不一样的,$varname[1]等价于${varname[0]}"[1]"。在csh下 $varname与${varname[*]}的含意是一样的。
[元素的添加、删除]
删除数组中元素:
该方法适用于bash、ksh,不支持csh。
unset varname[5]
关于数组中元素的值的清除,即置空:
bash和ksh下这样操作,不支持csh
varname[5]= #清除数组varname中的第六个元素
关于数组的清除:
适用于bash、ksh、csh等大部分shell。
unset varname
向数组中添加元素:
方法一、二只适用于bash、ksh,不适用于csh;
方法一:
varname=(${varname[*]} varn-1 varn varn+1)
方法二:
varname[${#varname[*]}]=varn
方法三:
是csh特有的。
set varname=($varname varn+1 varn+2) #或者$varname用${varname[*]}替换。
[关于数组的批量处理]
这部分内容,说白了就是综合运用各种shell的内建循环命令。只要对前面的内容熟悉了,并对各种shell的循环命令有一定的了解,难度就不是很大。
由于涉及bashkshcsh下的实现及不同的语法形式,涉及数组的赋值、添加和删除元素、读取多个方面。所以计划单独一篇文章来说明。



     本文转自xiaoyuwang 51CTO博客,原文链接:http://blog.51cto.com/wangxiaoyu/197652,如需转载请自行联系原作者



相关文章
|
12天前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
206 9
|
12天前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
68 2
|
1月前
|
算法 Linux Shell
Linux实用技能:打包压缩、热键、Shell与权限管理
本文详解Linux打包压缩技巧、常用命令与原理,涵盖.zip与.tgz格式操作、跨系统传文件方法、Shell运行机制及权限管理,助你高效使用Linux系统。
Linux实用技能:打包压缩、热键、Shell与权限管理
|
2月前
|
存储 Linux
Linux环境下删除大文件后磁盘空间未释放问题诊断流程。
以上诊断流程涉及Linux底层机制与高级管理技能结合之处,并需要管理员根据实际环境灵活调整诊断策略与解决方案。
120 8
|
3月前
|
Linux 数据安全/隐私保护 iOS开发
推荐Linux环境下效能优良的双向文件同步工具
综合上述条件,对于Linux环境下的双向文件同步需求,Unison 和 Syncthing 是两个非常出色的选择。它们都有良好的社区支持和文档资源,适用于不同规模的环境,从个人使用到商业部署。Unison 特别适合那些需要手动干预同步过程、需要处理文件冲突解决的场景。而 Syncthing 更加现代化,适合需要自动、实时的数据同步与备份的环境。对于选择哪一个,这将取决于个人的使用场景和具体需求。
337 16
|
3月前
|
安全 应用服务中间件 网络安全
在Linux环境部署Flask应用并启用SSL/TLS安全协议
至此,你的Flask应用应该能够通过安全的HTTPS协议提供服务了。记得定期更新SSL证书,Certbot可以帮你自动更新证书。可以设定cronjob以实现这一点。
222 10
|
3月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
233 1
|
2月前
|
Ubuntu 安全 Linux
Ubuntu 24.10 发行版登场:Linux 6.11 内核、GNOME 47 桌面环境
Ubuntu 24.10 还带来了 GNOME 47,增强了性能和稳定性,并引入了新功能。此版本的 Ubuntu 还默认在采用 Nvidia 显卡的硬件上切换到 Wayland,并在支持的硬件上默认使用开源的 Nvidia 560 内核模块。 另外需要注意的是,Ubuntu 24.10 是稳定版本,但作为非 LTS 版本,仅支持 9 个月。
|
2月前
|
安全 Linux 网络安全
Linux系统初步设置本地Git环境和生成SSH密钥的步骤。
现在您的Linux系统已经配置好了Git环境,并创建并添加了SSH密钥,可以安全地与远端仓库进行交互,无论是克隆、推送还是拉取操作。此过程确保了数据传输的安全并使版本控制流程更为顺畅。使用Git时应考虑定期更新并管理您的凭据,以确保安全性。
341 0