csh 脚本批量处理文件并将文件扔给程序

文章目录

前言

Linux下我们经常会写一些shell脚本来辅助我们学习或者工作,从而提高效率。

之前就写过一篇博客:Linux下利用shell脚本批量产生内容有规律变化的文件

程序

批量造 case 并将 cmd 扔给程序运行

bash 复制代码
#!/bin/csh -f


if ( $#argv != 2 ) then 
   echo
   echo " Usage: $0 cases temp.cmd"
   echo
endif

ls $1 >& list_tmp
# 将 list_tmp 文件中的 pattern_old 关键词都替换成 pattern_new 
sed "s/pattern_old/pattern_new/g" list_tmp >& list
rm list_tmp

# 获取 list 中共有多少行
set totalCaseNum = `sed -n '$=' list`

set n = 0
set topPath = `pwd`

mkdir result

foreach case (`cat list`)
   #echo case
   cd $topPath
   cd result
   mkdir $case
   cd $case

   cp $topPath/$2 $2.tmp
   
   # 将 $2.tmp 文件中的 pattern 关键词都换成 $case
   sed "s/pattern/$case/g" $2.tmp >& $2
   
   rm $2.tmp
   # 程序 运行
   program -i $2 -o $2.out >& $2.log
   
   @ n = $n + 1
   echo "Now running the $n case " $case ", Total case is " $totalCaseNum
end

批量收集数据汇总

bash 复制代码
#!/bin/csh -f


if ( $#argv != 1 ) then 
   echo
   echo " Usage: $0 cases"
   echo
endif

ls $1 >& list

# 获取 list 中共有多少行
set totalCaseNum = `sed -n '$=' list`

set n = 0
set topPath = `pwd`

foreach case (`cat list`)
   #echo case
   cd $topPath
   cd $1
   cd $case
   
   grep "Pattern $case" ${case}.out >> $topPath/result.txt
   
   @ n = $n + 1
   echo "Now running the $n case " $case ", Total case is " $totalCaseNum
end
相关推荐
君穆南7 小时前
基于 NFS 与 Rsync 实现跨服务器 Seafile 数据平滑迁移实战
linux·运维·git
bloglin999997 小时前
scp、rsync远程文件同步
linux·运维·服务器
迦南的迦 亚索的索7 小时前
LINUX环境
linux·运维·服务器
yuanjj887 小时前
linux下调试域格CLM920 NC5等9x07平台模块 QMI拨号
linux·运维·服务器
IMPYLH8 小时前
Linux 的 printenv 命令
linux·运维·服务器·bash
SilentSamsara8 小时前
SSH 远程管理:密钥登录 + 隧道转发,一次性配置好
linux·运维·服务器·ubuntu·centos·ssh
LN花开富贵8 小时前
【ROS】鱼香ROS2学习笔记一
linux·笔记·python·学习·嵌入式·ros·agv
疏星浅月8 小时前
数据对齐的底层原理与性能优化
linux
Jurio.8 小时前
本机开发 + 多机执行的极简远端运行工具
linux·git·python·github·远程工作
阿巴~阿巴~9 小时前
Git版本控制完全指南:从入门到实战(简单版)
linux·服务器·git