forked from log2akshat/UsefulScripts
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathBatchImageCompressionScript.py
More file actions
163 lines (138 loc) · 6.17 KB
/
BatchImageCompressionScript.py
File metadata and controls
163 lines (138 loc) · 6.17 KB
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
# Copyright (C) <2015> <Akshat Singh>
# <akshat-pg8@iiitmk.ac.in>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import os
import csv
import logging
import argparse
import platform
import subprocess
# Command line argument validation functions...
def is_valid_directory(parser, arg):
"Function for checking specfied directory exists or not."
if not os.path.isdir(arg):
parser.error('The directory {} does not exist!'.format(arg))
else:
# File exists so return the directory
return arg
def is_target_directory(arg):
"Function for checking specfied directory exists or not."
if not os.path.isdir(arg):
print('The directory %s does not exist!, so creating it for you..' % arg)
try:
subprocess.call(['mkdir', '-p', arg])
return arg
except:
parser.error('The directory {} does not exist and unable to create for you, please create it manually!'.format(arg))
else:
# File exists so return the directory
return arg
def is_valid_loggingStatus(parser, arg):
"Function for checking logging status is valid or not."
if not (arg == 'on' or arg == 'off'):
parser.error('{} is not a valid input for turning logging on or off! Please specify \"on\" for turning logging on and \"off\" for turning logging off.'.format(arg))
else:
return arg
## =========> Command line arguments parsing -- starts <========= ##
parser = argparse.ArgumentParser(description='Batch image conversion utility. For running this program you need to have imagemagick installed on your machine.')
parser.add_argument('-s','--source_directory', help='Directory to read input files.', required=True, metavar='<Source Directory>', type=lambda x: is_valid_directory(parser, x))
parser.add_argument('-t','--target_directory', help='Directory to save output files.', required=True, metavar='<Target Directory>', type=lambda x: is_target_directory(x))
parser.add_argument('-q','--quality', help='Quality of the Image to retain.', required=True, metavar='<Image Quality>')
parser.add_argument('-f','--filename', help='Desired output file name.', metavar='<Output file names>')
parser.add_argument('-l','--log_file', help='Path of the log file.', metavar='<Log File>')
parser.add_argument('-ls', '--logging_onoff', help='Logging status On/Off', metavar='<Logging on/off>', type=lambda x: is_valid_loggingStatus(parser, x))
args = parser.parse_args()
## =========> Command line arguments parsing -- ends <========= ##
subprocess.call('clear')
## =========> Logging Configurations -- starts <========= ##
loggerFile = args.log_file
loggingStatus = args.logging_onoff
if not loggerFile:
Log_File = '/tmp/BatchImageCompression.log'
else:
Log_File = loggerFile + ".log"
# create logger
logger = logging.getLogger('BIC')
logger.setLevel(logging.DEBUG)
# Turning logging on or off
if loggingStatus:
if loggingStatus == 'off':
logger.disabled = True
else:
logger.disabled = False
else:
logger.disabled = False
# add a file handler
fileHandler = logging.FileHandler(Log_File)
fileHandler.setLevel(logging.DEBUG)
# create console handler and set level to debug
consoleHandler = logging.StreamHandler()
consoleHandler.setLevel(logging.DEBUG)
# create formatter
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s', datefmt='%m/%d/%Y %I:%M:%S %p')
# add formatter to handlers
fileHandler.setFormatter(formatter)
consoleHandler.setFormatter(formatter)
# add ch to logger
logger.addHandler(fileHandler)
logger.addHandler(consoleHandler)
## =========> Logging Configurations -- ends <========= ##
filepath = args.source_directory
targetDir = args.target_directory
outfileName = args.filename
quality = args.quality
tmpFile = '/tmp/batchIM.txt'
devnull = open('/dev/null', 'w')
def processingFile():
'''Function to create a temporary file for processing.'''
file = []
filterCall = subprocess.Popen(['ls', filepath],stdout=subprocess.PIPE)
#tailCmd = subprocess.Popen(['tail', '-n+2'], stdin=filterCall.stdout, stdout=subprocess.PIPE)
if platform.system() == "Darwin":
sortCmd = subprocess.Popen(['sort', '-f'], stdin=filterCall.stdout, stdout=subprocess.PIPE)
elif platform.system() == "Linux":
sortCmd = subprocess.Popen(['sort', '--version-sort', '-f'], stdin=filterCall.stdout, stdout=subprocess.PIPE)
#awkCmd = subprocess.Popen(['awk', '{print substr($0,index($0,$9))}'], stdin=tailCmd.stdout, stdout=subprocess.PIPE)
teeCmd = subprocess.Popen(['tee', tmpFile], stdin=sortCmd.stdout, stdout=devnull)
sortCmd.stdout.close()
teeCmd.communicate()
def main():
processingFile()
i = 0
counter = 1
fileName = ""
pathfile = open(tmpFile, 'r')
file = pathfile.read().splitlines()
with open(tmpFile, 'r') as f:
reader = csv.reader(f, delimiter=' ')
for row in reader:
pathRow = row[0:]
length = len(pathRow)
if i < length:
for x in pathRow:
fileName = fileName + " " + pathRow[i]
i = i + 1
fileName = fileName.strip()
imgpath = filepath + fileName
logger.info("Resizing Image : %s.." % imgpath)
if outfileName:
subprocess.call(['convert', imgpath, '-quality', quality, str(targetDir) + '/' + str(outfileName) + ' ' + str(counter) + '.jpg'])
else:
subprocess.call(['convert', imgpath, '-quality', quality, str(targetDir) + '/' + fileName])
i = 0
fileName = ""
counter = counter + 1
if __name__ == "__main__":
main()