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

相关文章

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Linux find 命令完全指南及核心用法

《Linuxfind命令完全指南及核心用法》find是Linux系统最强大的文件搜索工具,支持嵌套遍历、条件筛选、执行动作,下面给大家介绍Linuxfind命令完全指南,感兴趣的朋友一起看看吧... 目录一、基础搜索模式1. 按文件名搜索(精确/模糊匹配)2. 排除指定目录/文件二、根据文件类型筛选三、时间

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

Windows命令之tasklist命令用法详解(Windows查看进程)

《Windows命令之tasklist命令用法详解(Windows查看进程)》tasklist命令显示本地计算机或远程计算机上当前正在运行的进程列表,命令结合筛选器一起使用,可以按照我们的需求进行过滤... 目录命令帮助1、基本使用2、执行原理2.1、tasklist命令无法使用3、筛选器3.1、根据PID

Linux系统之authconfig命令的使用解读

《Linux系统之authconfig命令的使用解读》authconfig是一个用于配置Linux系统身份验证和账户管理设置的命令行工具,主要用于RedHat系列的Linux发行版,它提供了一系列选项... 目录linux authconfig命令的使用基本语法常用选项示例总结Linux authconfi

通过Python脚本批量复制并规范命名视频文件

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,... 目录一、问题场景:杂乱的视频文件名二、完整解决方案三、关键技术解析1. 智能路径处理2. 精准文件名

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re

linux打包解压命令方式

《linux打包解压命令方式》文章介绍了Linux系统中常用的打包和解压命令,包括tar和zip,使用tar命令可以创建和解压tar格式的归档文件,使用zip命令可以创建和解压zip格式的压缩文件,每... 目录Lijavascriptnux 打包和解压命令打包命令解压命令总结linux 打包和解压命令打

Python3脚本实现Excel与TXT的智能转换

《Python3脚本实现Excel与TXT的智能转换》在数据处理的日常工作中,我们经常需要将Excel中的结构化数据转换为其他格式,本文将使用Python3实现Excel与TXT的智能转换,需要的可以... 目录场景应用:为什么需要这种转换技术解析:代码实现详解核心代码展示改进点说明实战演练:从Excel到

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi