mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-25 00:34:14 +03:00
4e754e9c55
cf. #1191. Only TiffImagePlugin and OLEFileIO still rely on (their own) DEBUG flag. I left TiffImagePlugin as it is because I hope #1059 gets merged in first, and OLEFileIO because it uses its own logic. Untested, as usual.
102 lines
2.6 KiB
Python
102 lines
2.6 KiB
Python
#!/usr/bin/env python
|
|
#
|
|
# The Python Imaging Library.
|
|
# $Id$
|
|
#
|
|
# a utility to identify image files
|
|
#
|
|
# this script identifies image files, extracting size and
|
|
# pixel mode information for known file formats. Note that
|
|
# you don't need the PIL C extension to use this module.
|
|
#
|
|
# History:
|
|
# 0.0 1995-09-01 fl Created
|
|
# 0.1 1996-05-18 fl Modified options, added debugging mode
|
|
# 0.2 1996-12-29 fl Added verify mode
|
|
# 0.3 1999-06-05 fl Don't mess up on class exceptions (1.5.2 and later)
|
|
# 0.4 2003-09-30 fl Expand wildcards on Windows; robustness tweaks
|
|
#
|
|
|
|
from __future__ import print_function
|
|
|
|
import getopt
|
|
import glob
|
|
import logging
|
|
import sys
|
|
|
|
from PIL import Image
|
|
|
|
if len(sys.argv) == 1:
|
|
print("PIL File 0.4/2003-09-30 -- identify image files")
|
|
print("Usage: pilfile [option] files...")
|
|
print("Options:")
|
|
print(" -f list supported file formats")
|
|
print(" -i show associated info and tile data")
|
|
print(" -v verify file headers")
|
|
print(" -q quiet, don't warn for unidentified/missing/broken files")
|
|
sys.exit(1)
|
|
|
|
try:
|
|
opt, args = getopt.getopt(sys.argv[1:], "fqivD")
|
|
except getopt.error as v:
|
|
print(v)
|
|
sys.exit(1)
|
|
|
|
verbose = quiet = verify = 0
|
|
logging_level = "WARNING"
|
|
|
|
for o, a in opt:
|
|
if o == "-f":
|
|
Image.init()
|
|
id = sorted(Image.ID)
|
|
print("Supported formats:")
|
|
for i in id:
|
|
print(i, end=' ')
|
|
sys.exit(1)
|
|
elif o == "-i":
|
|
verbose = 1
|
|
elif o == "-q":
|
|
quiet = 1
|
|
elif o == "-v":
|
|
verify = 1
|
|
elif o == "-D":
|
|
logging_level = "DEBUG"
|
|
|
|
logging.basicConfig(level=logging_level)
|
|
|
|
|
|
def globfix(files):
|
|
# expand wildcards where necessary
|
|
if sys.platform == "win32":
|
|
out = []
|
|
for file in files:
|
|
if glob.has_magic(file):
|
|
out.extend(glob.glob(file))
|
|
else:
|
|
out.append(file)
|
|
return out
|
|
return files
|
|
|
|
for file in globfix(args):
|
|
try:
|
|
im = Image.open(file)
|
|
print("%s:" % file, im.format, "%dx%d" % im.size, im.mode, end=' ')
|
|
if verbose:
|
|
print(im.info, im.tile, end=' ')
|
|
print()
|
|
if verify:
|
|
try:
|
|
im.verify()
|
|
except:
|
|
if not quiet:
|
|
print("failed to verify image", end=' ')
|
|
print("(%s:%s)" % (sys.exc_info()[0], sys.exc_info()[1]))
|
|
except IOError as v:
|
|
if not quiet:
|
|
print(file, "failed:", v)
|
|
except:
|
|
import traceback
|
|
if not quiet:
|
|
print(file, "failed:", "unexpected error")
|
|
traceback.print_exc(file=sys.stdout)
|