一个简单的shell面试题引发的总结

发布时间:2020-08-16 07:15:44 作者:残夜寻茶香
来源:网络 阅读:615

 最近闲来无事,在网上搜一些shell面试题做一做,今天看到一个面试时候经常被考的一个题,原题如下:

    批量添加20个用户到class01组,用户名以std开头,以数字结尾,格式:std01---std20

 这个题在面试的时候貌似经常能见到吧,大家都懂得,但是也很简单,大家要注意题意,注意格式,要求是std01这样的格式,如果只是一个简单的for,用户名很可能是std1哦。不多说,先上一下我的简陋的脚本,一个同学说我的脚本很凌乱,哈哈,确实是凌乱在风雨中啊。

 

#!/bin/sh
groupadd class01
a=std
for ((i=1;i<=20;i++))
do
if [ $i -lt 10 ];then
username="$a"0"$i"
else
username=$a$i
fi
useradd -G class01 -M  $username
done

在执行脚本的时候碰到一个问题,总是提示我的第四行语法错误,检查半天也没发现我这语法案例出错了,没办法只好问问Google大叔了。果然,网上有好多人碰到这个问题,究其原因是我的系统是ubuntu的,在ubuntu下,默认的shell不是bash,而是dash,dash 比 bash 更轻,更快。但 bash 却更常用。虽然更快更轻了,但是还是不兼容啊,没办法,换回来吧,解决方法:sudo dpkg-reconfigure dash,然后选择no,好了,现在以及切回来了,可以正确执行,没问题。

  接下来上一下我同学的脚本吧,虽然也不是最佳的,但是思路跟我的差不多,严重怀疑这哥们是不是抄袭了,哈哈,比我的还是优化了一些。

 

#!/bin/bash
groupadd class01
for i in {1..20}
do
if  [ $i -lt 10 ];then
useradd "std0$i" -g class01
else
useradd "std$i" -g class01
fi
done

  好吧,其实我也没看出号多少,哈哈~~反正都能实现,解决问题就可以。

 最后来一下我们的热心网友的脚本吧,这叫一个简练啊,一句话shell

 

for i in `seq -w 20`;do useradd -G class01 sdt$i;done

 好吧,看了这个脚本,心里这个凌乱啊,基础不扎实啊,人家一个seq -w就解决了,哎~~

 seq:用于产生从某个数到另外一个数之间的所有整数
  # seq 1 10
  结果是1 2 3 4 5 6 7 8 9 10
 seq的参数
-f, --format=FORMAT      use printf style floating-point FORMAT (default: %g)
-s, --separator=STRING   use STRING to separate numbers (default: /n)
-w, --equal-width        equalize width by padding with leading zeroes

-f 选项   指定格式

root@addam-python:~# seq -f"%3g" 1 10
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10

% 后面指定数字的位数 默认是"%g",

"%3g"那么数字位数不足部分是空格
#sed -f"%03g" 1 11 这样的话数字位数不足部分是0

root@addam-python:~# seq -f"%03g" 1 11
001
002
003
004
005
006
007
008
009
010
011

% 前面制定字符串

root@addam-python:~# seq -f "test%03g" 8 12
test008
test009
test010
test011
test012


-w 指定输出数字同宽   不能和-f一起用

root@addam-python:~# seq -w 1 10
01
02
03
04
05
06
07
08
09
10

输出是同宽的

学习一个脚本,同时也加固一下seq的学习,好记性不如烂笔头~~

推荐阅读:
  1. 存储器的简单总结
  2. 一个<<-EOF引发的血案

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

批量添加用户 seq he

上一篇:MySQL基操---深入浅出增量断点备份与日志管理

下一篇:error while loading shared libraries: libmysqlclient.so.16: cannot open shared object file: No such

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》