-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemplate.py
45 lines (37 loc) · 1.49 KB
/
template.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
# The project template is different for ML & DL projects. Respective file for ML projects is on the github repo. as "end-to-end-ml-project-with-mlflow". And for DL projects, the file is as below.
import os
from pathlib import Path
import logging
# My Logging string which will be used everywhere we want to log messages...
logging.basicConfig(level=logging.INFO, format='[%(asctime)s]: %(message)s:')
project_name = 'cnnClassifier'
list_of_files = [
".github/workflows/.gitkeep",
f"src/{project_name}/__init__.py",
f"src/{project_name}/components/__init__.py",
f"src/{project_name}/utils/__init__.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}/entity/__init__.py",
f"src/{project_name}/constants/__init__.py",
"config/config.yaml",
"dvc.yaml",
"params.yaml",
"requirements.txt",
"setup.py",
"research/trials.ipynb",
"templates/index.html"
]
for filepath in list_of_files:
filepath = Path(filepath)
filedir, filename = os.path.split(filepath)
if filedir != "":
os.makedirs(filedir,exist_ok=True)
logging.info(f"Creating directory : {filedir} for the file : {filename}")
if(not os.path.exists(filepath)) or (os.path.getsize(filepath)==0):
with open(filepath,'w') as f:
pass
logging.info(f"Creating empty file : {filepath}")
else:
logging.info(f"{filename} already exists")