답변:
아래의 파이썬 스크립트가 작업을 수행합니다. 숨겨진 파일은 폴더와 확장자가없는 파일에 별도로 저장됩니다.
광범위한 목적으로 사용될 수 있으므로 몇 가지 옵션을 추가했습니다.
exclude = ()
remove_emptyfolders = True
또는 False
)shutil.move(subject, new_dir+"/"+name)
으로:
shutil.copy(subject, new_dir+"/"+name)
스크립트 :
#!/usr/bin/env python3
import os
import subprocess
import shutil
# --------------------------------------------------------
reorg_dir = "/path/to/directory_to_reorganize"
exclude = (".jpg") # for example
remove_emptyfolders = True
# ---------------------------------------------------------
for root, dirs, files in os.walk(reorg_dir):
for name in files:
subject = root+"/"+name
if name.startswith("."):
extension = ".hidden_files"
elif not "." in name:
extension = ".without_extension"
else:
extension = name[name.rfind("."):]
if not extension in exclude:
new_dir = reorg_dir+"/"+extension[1:]
if not os.path.exists(new_dir):
os.mkdir(new_dir)
shutil.move(subject, new_dir+"/"+name)
def cleanup():
filelist = []
for root, dirs, files in os.walk(reorg_dir):
for name in files:
filelist.append(root+"/"+name)
directories = [item[0] for item in os.walk(reorg_dir)]
for dr in directories:
matches = [item for item in filelist if dr in item]
if len(matches) == 0:
try:
shutil.rmtree(dr)
except FileNotFoundError:
pass
if remove_emptyfolders == True:
cleanup()
중복 파일을 원하지 않는 덮어 쓰기의 위험이있는 경우
몇 줄이 추가 될 경우 중복 가능성을 덮어 쓰는 것을 방지 할 수 있습니다. 아래 코드를 사용하면 중복 이름이 다음과 같이 바뀝니다.
duplicate_1_filename, duplicate_2_filename
기타
스크립트 :
#!/usr/bin/env python3
import os
import subprocess
import shutil
# --------------------------------------------------------
reorg_dir = "/path/to/directory_to_reorganize"
exclude = (".jpg") # for example
remove_emptyfolders = True
# ---------------------------------------------------------
for root, dirs, files in os.walk(reorg_dir):
for name in files:
subject = root+"/"+name
if name.startswith("."):
extension = ".hidden_files"
elif not "." in name:
extension = ".without_extension"
else:
extension = name[name.rfind("."):]
if not extension in exclude:
new_dir = reorg_dir+"/"+extension[1:]
if not os.path.exists(new_dir):
os.mkdir(new_dir)
n = 1; name_orig = name
while os.path.exists(new_dir+"/"+name):
name = "duplicate_"+str(n)+"_"+name_orig
n = n+1
newfile = new_dir+"/"+name
shutil.move(subject, newfile)
def cleanup():
filelist = []
for root, dirs, files in os.walk(reorg_dir):
for name in files:
filelist.append(root+"/"+name)
directories = [item[0] for item in os.walk(reorg_dir)]
for dr in directories:
matches = [item for item in filelist if dr in item]
if len(matches) == 0:
try:
shutil.rmtree(dr)
except FileNotFoundError:
pass
if remove_emptyfolders == True:
cleanup()
OP를 염두에두고 사용 방법에 대한 지침을 추가하는 것을 잊었습니다. 중복 질문 (수 있으므로 및 수행 ) 표시, 그럼에도 불구하고 유용 할 수 있습니다.
reorganize.py
스크립트의 헤드 섹션에서 대상 파일을 재구성 할 파일과 함께 설정하십시오.
reorg_dir = "/path/to/directory_to_reorganize"
(디렉토리에 공백이 있으면 따옴표를 사용하십시오)
제외하려는 확장 프로그램 (아마도 아래와 같이 없음) :
exclude = ()
나중에 빈 폴더를 제거하려면 다음을 수행하십시오.
remove_emptyfolders = True
다음 명령으로 스크립트를 실행하십시오.
python3 /path/to/reorganize.py
NB move 대신 파일 을 복사 하려면 다음을 바꾸십시오.
shutil.move(subject, new_dir+"/"+name)
으로:
shutil.copy(subject, new_dir+"/"+name)
작은 샘플로 먼저 시도하십시오.
find
다소 복잡한 exec
명령 과 함께 사용할 수 있습니다 .
find . -iname '*?.?*' -type f -exec bash -c 'EXT="${0##*.}"; mkdir -p "$PWD/${EXT}_dir"; cp --target-directory="$PWD/${EXT}_dir" "$0"' {} \;
# '*?.?*' requires at least one character before and after the '.',
# so that files like .bashrc and blah. are avoided.
# EXT="${0##*.}" - get the extension
# mkdir -p $PWD/${EXT}_dir - make the folder, ignore if it exists
드라 이런 cp
으로 교체하십시오 echo
.
보다 효율적이고 깔끔한 것은 bash
명령을 스크립트 에 저장하는 것입니다 (예 /path/to/the/script.sh
: at ).
#! /bin/bash
for i
do
EXT="${i##*.}"
mkdir -p "$PWD/${EXT}_dir"
mv --target-directory="$PWD/${EXT}_dir" "$i"
done
그런 다음 다음을 실행하십시오 find
.
find . -iname '*?.?*' -type f -exec /path/to/the/script.sh {} +
이 방법은 매우 유연합니다. 예를 들어, 확장자 ( filename.ext
) 대신 파일 이름을 사용 하려면 다음과 같이 사용합니다 EXT
.
NAME="${i##*/}"
EXT="${NAME%.*}"
*.fig.bak
또는 .profile/.bashrc
사람,하지만 그것은 단지 적어도 확장자를 가진 파일을 처리해야합니다. 감사.
ls | gawk -F. 'NF>1 {f= $NF "-DIR"; system("mkdir -p " f ";mv " $0 " " f)}'
확장 목록 계산 (이동 후) :
ls -d *-DIR
확장 목록 계산하기 (이동 전) :
ls -X | grep -Po '(?<=\.)(\w+)$'| uniq -c | sort -n
(이 마지막 예에서, 우리는 각 확장에 대한 파일 수를 계산하고 정렬합니다)
ls -X
. 내가 권장하지 않는 이유 ls
는 unix.stackexchange.com/q/128985/70524 및 unix.stackexchange.com/q/112125/70524를 참조하십시오 . 당신이하는 일을 달성하기 위해 더 긴 길을 갈 것입니다 : find . -type f -name '*?.?*' -print0 | sed -z 's/.*\.//' | sort -zu
( | uniq -cz
카운트가 필요한 경우 선택 사항 ). 그리고 처음에는 (이것이 이식성find ... -print0 | gawk -v RS='\0'
이 좋지 는 않지만 ).
이 쉘 스크립트를 사용해보십시오.
#!/bin/sh
src=`dirname "$1"`/`basename "$1"`;
for file in "$src"/*?.?*; do
if test -f "$file"; then
dest="$src${file##*.}"_files;
mkdir -p "$dest";
mv "$file" "$dest";
fi;
done;
# pass the directory to re-organize as first argument
# moves only regular files which have extension
# ignores other type of files including
# files having no extension, hidden files, directories, and links.
filepath
와를 file
. 직접 수정하겠습니다.
for file in "$src"/*?.?*; do ..
read
예상치 못한 동작이있을 수 있습니다. 또한 mkdir 및 mv 명령에서 변수를 인용해야합니다.
for i in *; do printf "%s\n" "$i"; done; for i in $(ls -d); do printf "%s\n" "$i"; done
-iname '*.*'
내가 대해 ... 좋은 생각이 걱정 된 코너 케이스의주의를 기울여야한다!