Shell脚本实现根据文件的修改时间来分类文件
#!/bin/bash # exctute # ./mod.sh file_type input_folder output_folder # ./mod.sh *.txt /tmp /data/ # paramater count if [ ! $# -eq 3 ]; then echo "[ERROR] error paramater." exit fi # file type file_type="${1}" # input foloder if [ -d "${2}" ]; then folder="${2}" else echo "[ERROR] input folder is not exsit." exit fi # output folder if [ -d "${3}" ]; then output="${3}" else echo "[ERROR] output folder is not exsit." exit fi # search file find ${folder} -name "${file_type}" | while read filename ; do # file type file_type=`echo ${filename##*.}` # file size file_size=`stat "${filename}" | sed -n '2,1p' | awk '{print $2}' ` # file modify time file_modify=`stat "${filename}" | sed -n '6,1p' | awk '{print $2, $3}' | sed -e 's/[-: ]//g' ` # output folder path="${output}/${file_modify:0:6}" if [ ! -d "${path}" ]; then mkdir -p ${path} echo "folder(${path}) is created . " fi # new file full name new_file_name=`echo ${path}/${file_modify}_[${file_size}].${file_type}` if [ ! -f "${new_file_name}" ]; then mv "${filename}" "${new_file_name}" else echo "file(${new_file_name}) is exsit, can not be removed. " fi done echo "finished !" exit
Shell动态生成数组的多种方法
如果对linuxshell数组不是很熟悉的话,请看上一篇文章:linuxshell数组建立及使用技巧,这篇文章主要讲是动态生成数组系列。方法应该很多,我这里主要
Shell中创建序列和数组(list、array)的方法
关于linux数组定义,以及生成方法,请看:linuxshell动态生成数组系列seq使用技巧。这里我主要说的是高效生成list字符串,还有数组方法。一、seq方法生
Linux Shell 数组的创建及使用技巧
linuxshell在编程方面比windows批处理强大太多,无论是在循环、运算。已经数据类型方面都是不能比较的。下面是个人在使用时候,对它在数组方面一些操