-
Notifications
You must be signed in to change notification settings - Fork 1
/
structure.py
62 lines (54 loc) · 2.04 KB
/
structure.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import logging
import os
from pathlib import Path
# CREATE THE INITIAL PROJECT STRUCTURE
# Set up logging
logging.basicConfig(level=logging.INFO, format="[%(asctime)s]: %(message)s:")
project_name = "DeepfakeDetection"
list_of_files = [
".github/workflows/.gitkeep",
f"src/{project_name}/__init__.py",
f"src/{project_name}/components/__init__.py",
f"src/{project_name}/components/data_ingestion.py",
f"src/{project_name}/components/data_preprocessing.py",
f"src/{project_name}/components/model_training.py",
f"src/{project_name}/components/model_evaluation.py",
f"src/{project_name}/utils/__init__.py",
f"src/{project_name}/utils/common.py",
f"src/{project_name}/config/__init__.py",
f"src/{project_name}/config/configuration.py",
f"src/{project_name}/pipeline/__init__.py",
f"src/{project_name}/pipeline/prediction.py",
f"src/{project_name}/pipeline/stage_01_data_ingestion.py",
f"src/{project_name}/pipeline/stage_02_data_preprocessing.py",
f"src/{project_name}/pipeline/stage_03_model_training.py",
f"src/{project_name}/pipeline/stage_04_model_evaluation.py",
f"src/{project_name}/entity/__init__.py",
f"src/{project_name}/entity/config_entity.py",
f"src/{project_name}/constants/__init__.py",
"config/config.yaml",
"dvc.yaml",
"main.py",
"params.yaml",
"requirements.txt",
"notebook/main.ipynb",
".gitignore",
".dvcignore",
"app.py",
"Dockerfile",
".env",
"pyproject.toml",
]
for filepath in list_of_files:
filepath = Path(filepath)
filedir, filename = os.path.split(filepath)
# create the directory if not exists
if filedir != "":
os.makedirs(filedir, exist_ok=True)
logging.info(f"Created directory: {filedir} for the file: {filename}")
# create the file if not exists
if (not os.path.exists(filepath)) or (os.path.getsize(filepath) == 0):
with open(filepath, "w") as f:
logging.info(f"Created empty file: {filepath}")
else:
logging.info(f"File {filename} already exists")