modulos movidos para pasta 'modules'
This commit is contained in:
50
copier.py
50
copier.py
@ -1,50 +0,0 @@
|
||||
# copier.py
|
||||
# Funções para copiar ficheiros para o destino organizado
|
||||
from . import organizer
|
||||
from pathlib import Path
|
||||
import shutil
|
||||
|
||||
|
||||
def copiar_ficheiro(origem, destino):
|
||||
"""
|
||||
Copia o ficheiro da origem para o destino.
|
||||
Deve lidar com conflitos de nomes (duplicados).
|
||||
"""
|
||||
pass
|
||||
|
||||
|
||||
def copiar_ficheiros_para_destino(
|
||||
lista_ficheiros: list[str],
|
||||
base_destino: str,
|
||||
categorizar_data: bool = False,
|
||||
usar_criacao: bool = False,
|
||||
formato_data: str = "%d-%m-%Y",
|
||||
) -> None:
|
||||
"""
|
||||
Copiar cada ficheiro na lista para o directório base, seguindo as regras de categorização
|
||||
|
||||
argumentos:
|
||||
lista_ficheiros (list[str]) -> lista com o caminho dos ficheiros a serem copiados
|
||||
base_destino (str) -> directorio base no qual serão criados os novos directórios com base nas regras de categorização
|
||||
categorizar_data (bool) -> flag para activar categorização por data (defeito: False)
|
||||
usar_criacao (bool) -> usar data de criação (defeito: False usar data de modificacao)
|
||||
formato_data (str) -> formato de data para nome dos subdirectórios (defeito: '%d-%m-%Y')
|
||||
|
||||
retorna:
|
||||
None
|
||||
"""
|
||||
for ficheiro in lista_ficheiros:
|
||||
if not Path(ficheiro).is_file():
|
||||
print(f"Aviso: '{ficheiro}' não existe ou não é um ficheiro.")
|
||||
continue
|
||||
categoria = organizer.categorizar_por_tipo(ficheiro)
|
||||
data = (
|
||||
organizer.obter_data_ficheiro(ficheiro, usar_criacao)
|
||||
if categorizar_data
|
||||
else None
|
||||
)
|
||||
pasta_destino = organizer.criar_pasta_destino(
|
||||
base_destino, categoria, data, formato_data
|
||||
)
|
||||
destino_final = pasta_destino / Path(ficheiro).name
|
||||
shutil.copy2(ficheiro, destino_final)
|
||||
@ -1,9 +0,0 @@
|
||||
# logger.py
|
||||
# Função para escrever logs do processo
|
||||
|
||||
|
||||
def registar_log(mensagem):
|
||||
"""
|
||||
Escreve mensagem no ficheiro de log.
|
||||
"""
|
||||
pass
|
||||
69
organizer.py
69
organizer.py
@ -1,69 +0,0 @@
|
||||
# organizer.py
|
||||
# Funções para categorizar ficheiros e criar estrutura de destino
|
||||
from pathlib import Path
|
||||
from datetime import datetime
|
||||
|
||||
|
||||
def categorizar_por_tipo(ficheiro: str) -> str:
|
||||
"""
|
||||
Devolve o tipo de ficheiro (imagem, documento, vídeo, etc) com base na extensão.
|
||||
|
||||
argumentos:
|
||||
ficheiro (str) -> caminho do ficheiro
|
||||
|
||||
retorna:
|
||||
str -> tipo de ficheiro
|
||||
"""
|
||||
# TODO: extensões configuraveis externamente pelo utilizador
|
||||
extensao = Path(ficheiro).suffix.lower()
|
||||
if extensao in [".jpeg", ".jpg", ".bmp", ".cr2", ".raw"]:
|
||||
return "imagem"
|
||||
elif extensao in [".pdf", ".doc", ".docx", ".xls", ".xlsx"]:
|
||||
return "documento"
|
||||
elif extensao in [".mp4", ".mpeg", ".mov"]:
|
||||
return "video"
|
||||
else:
|
||||
return "outros"
|
||||
|
||||
|
||||
def obter_data_ficheiro(ficheiro: str, usar_criacao: bool = False) -> datetime:
|
||||
"""
|
||||
Devolve a data de modificação ou criação do ficheiro.
|
||||
|
||||
argumentos:
|
||||
ficheiro (str) -> caminho do ficheiro
|
||||
usar_criacao (bool) -> retornar data de criação de ficheiro (defeito: False)
|
||||
|
||||
retorna:
|
||||
datetime -> data de modificação ou criação do ficheiro
|
||||
"""
|
||||
stats_ficheiro = Path(ficheiro).stat()
|
||||
timestamp = stats_ficheiro.st_ctime if usar_criacao else stats_ficheiro.st_mtime
|
||||
return datetime.fromtimestamp(timestamp)
|
||||
|
||||
|
||||
def criar_pasta_destino(
|
||||
base_destino: str,
|
||||
categoria: str,
|
||||
data: datetime | None = None,
|
||||
formato_data: str = "%d-%m-%Y",
|
||||
) -> Path:
|
||||
"""
|
||||
Cria a pasta de destino apropriada, se não existir.
|
||||
|
||||
argumentos:
|
||||
base_destino (str) -> directorio raiz para criar novo directorio
|
||||
categoria (str) -> nome do novo directorio a criar
|
||||
data (datetime | None) -> nome para subdirectorio para categorizar por data (defeito: None, não criar subdirectorio de data)
|
||||
formato_data (str) -> formato da data ppara o nome da pasta (defeito: '%d-%m-%Y')
|
||||
|
||||
retorna:
|
||||
Path -> caminho completo para o novo directorio criado
|
||||
"""
|
||||
if isinstance(data, datetime):
|
||||
data_directorio = data.strftime(formato_data)
|
||||
else:
|
||||
data_directorio = ""
|
||||
caminho_novo_directorio = Path(base_destino) / categoria / data_directorio
|
||||
caminho_novo_directorio.mkdir(parents=True, exist_ok=True)
|
||||
return caminho_novo_directorio
|
||||
2
pytest.ini
Normal file
2
pytest.ini
Normal file
@ -0,0 +1,2 @@
|
||||
[pytest]
|
||||
pythonpath = .
|
||||
23
scanner.py
23
scanner.py
@ -1,23 +0,0 @@
|
||||
# scanner.py
|
||||
# Funções para ler diretórios e listar ficheiros
|
||||
from pathlib import Path
|
||||
|
||||
|
||||
def listar_ficheiros(origem: str = ".") -> list:
|
||||
"""
|
||||
Percorrer recursivamente a pasta de origem e devolver lista de caminhos completos dos ficheiros.
|
||||
versão Pathlib
|
||||
"""
|
||||
lista_caminhos_ficheiros: list = []
|
||||
try:
|
||||
caminho_origem = Path(origem)
|
||||
for item in caminho_origem.iterdir():
|
||||
if item.is_dir():
|
||||
lista_caminhos_ficheiros.extend(listar_ficheiros(str(item.resolve())))
|
||||
else:
|
||||
lista_caminhos_ficheiros.append(str(item.resolve()))
|
||||
except FileNotFoundError:
|
||||
print(f"Erro: a pasta '{origem}' não existe.")
|
||||
except PermissionError:
|
||||
print(f"Erro: sem permissões para aceder a '{origem}'.")
|
||||
return lista_caminhos_ficheiros
|
||||
Reference in New Issue
Block a user