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批处理强大太多,无论是在循环、运算。已经数据类型方面都是不能比较的。下面是个人在使用时候,对它在数组方面一些操