hylan:shell脚本鸡肋--结构化命令(续)

2024-05-02 21:58

本文主要是介绍hylan:shell脚本鸡肋--结构化命令(续),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1.   循环处理数据效果:
  2. marvin@marvin-pc:~$ cat /etc/passwd | grep marvin
    marvin:x:1000:1000:marvin,,,:/home/marvin:/bin/bash
    marvin@marvin-pc:~$ ifs=$IFS
    marvin@marvin-pc:~$ IFS=:
    marvin@marvin-pc:~$ for haha in $(cat /etc/passwd | grep marvin)
    > do
    > echo "this is $haha"
    > done
    this is marvin
    this is x
    this is 1000
    this is 1000
    this is marvin,,,
    this is /home/marvin
    this is /bin/bash
  3.   嵌套循环处理文件数据: 
  4. #!/bin/bash
    #_*_coding:utf-8_*_
    #写个程序拆分/etc/passwd文件中的数据
    IFS_old=$IFS
    IFS=$'\n'
    for split_out in $(cat /etc/passwd)
    do
        echo "文件中的数据 $split_out"
        IFS=:
        for split_in in $split_out
        do
           echo "   $split_in"
        done
    done
    IFS=$IFS_old
  5.   查找可执行文件 
  6. #!/bin/bash
    #_*_coding: utf-8_*_
    #查找可执行的文件
    IFS_old=$IFS
    IFS=:

    for folder in $PATH
    do
        echo "$folder:"

        for file in $folder/*
        do
            if [ -x $file ]
            then
                echo "    $file"
            fi
        done
    done

  7.   一次性创建多个系统用户 
  8. #!/bin/bash
    #_*_coding: utf-8_*_
    #通过文件一次性创建多个账号

    input="users.csv"
    while IFS=',' read -r userid name
    do
        echo "新增用户:$userid"
        useradd -c "$name" -m $userid
    done < "$input"
  9.  读取.csv文件,创建insert语句 
  10. csv文件内容如下:
  11. marvin@marvin-pc:~/hylan$ cat members.csv
    Blum,Richard,123 Main St.,Chicago,IL,60601
    Blum,Barbara,123 Main St.,Chicago,IL,60601
    Bresnahan,Christine,456 Oak Ave,Columbus,OH,43201
    Bresnahan,Timothy,456 Oak Ave,Columbus,OH,43201

  12. marvin@marvin-pc:~/hylan$ cat sql_test
    #!/bin/bash

    outfile='members.sql'
    IFS=','

    while read lname fname address city state zip
    do
        cat >> $outfile << EOF
    insert into members(lname,fname,address,city,state,zip) values
    ('$lname','$fname','$address','$city','$state','$zip');
    EOF
    done
  13. 执行脚本:marvin@marvin-pc:~/hylan$ ./sql_test < members.csv

  14. 执行结果:marvin@marvin-pc:~/hylan$ cat members.sql
    insert into members(lname,fname,address,city,state,zip) values
    ('Blum','Richard','123 Main St.','Chicago','IL','60601');
    insert into members(lname,fname,address,city,state,zip) values
    ('Blum','Barbara','123 Main St.','Chicago','IL','60601');
    insert into members(lname,fname,address,city,state,zip) values
    ('Bresnahan','Christine','456 Oak Ave','Columbus','OH','43201');
    insert into members(lname,fname,address,city,state,zip) values
    ('Bresnahan','Timothy','456 Oak Ave','Columbus','OH','43201');
    insert into members(lname,fname,address,city,state,zip) values
    ('','','','','','');


    注意最后多了一行空值。可能需要手动处理一下。之所以会产生这条空行,是因为members.csv文件我不是用vim创建的文件,手工打开的编辑器,误留了空行(比较容易无意中留空行),如果是用vim编辑器创建的文件(不容易误留空行),没有放空行就不会出现这种空行。







这篇关于hylan:shell脚本鸡肋--结构化命令(续)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/955223

相关文章

10个Python自动化办公的脚本分享

《10个Python自动化办公的脚本分享》在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的Python自动化办公案例及源码,希望对大家有所帮助... 目录1. 批量处理 Excel 文件2. 自动发送邮件3. 批量重命名文件4. 数据清洗5. 生成 PPT6. 自动化测试

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

10个Python Excel自动化脚本分享

《10个PythonExcel自动化脚本分享》在数据处理和分析的过程中,Excel文件是我们日常工作中常见的格式,本文将分享10个实用的Excel自动化脚本,希望可以帮助大家更轻松地掌握这些技能... 目录1. Excel单元格批量填充2. 设置行高与列宽3. 根据条件删除行4. 创建新的Excel工作表5

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用