diff --git a/Tests/helper.py b/Tests/helper.py index 282482940..302e1f6ac 100644 --- a/Tests/helper.py +++ b/Tests/helper.py @@ -4,9 +4,11 @@ Helper functions. import logging import os +import subprocess import sys import tempfile import unittest +from io import BytesIO from PIL import Image, ImageMath @@ -284,14 +286,10 @@ class PillowLeakTestCase(PillowTestCase): def fromstring(data): - from io import BytesIO - return Image.open(BytesIO(data)) def tostring(im, string_format, **options): - from io import BytesIO - out = BytesIO() im.save(out, string_format, **options) return out.getvalue() @@ -323,8 +321,6 @@ def command_succeeds(cmd): Runs the command, which must be a list of strings. Returns True if the command succeeds, or False if an OSError was raised by subprocess.Popen. """ - import subprocess - with open(os.devnull, "wb") as f: try: subprocess.call(cmd, stdout=f, stderr=subprocess.STDOUT) diff --git a/Tests/test_file_libtiff.py b/Tests/test_file_libtiff.py index f92fc3b9b..e9e6d0587 100644 --- a/Tests/test_file_libtiff.py +++ b/Tests/test_file_libtiff.py @@ -1,3 +1,4 @@ +import base64 import distutils.version import io import itertools @@ -840,8 +841,6 @@ class TestFileLibTiff(LibTiffTestCase): # Assert that a TIFF image with SampleFormat=UINT tag is not corrupted # when saving to a new file. # Pillow 6.0 fails with "OSError: cannot identify image file". - import base64 - tiff = io.BytesIO( base64.b64decode( b"SUkqAAgAAAAPAP4ABAABAAAAAAAAAAABBAABAAAAAQAAAAEBBAABAAAAAQAA" diff --git a/Tests/test_file_libtiff_small.py b/Tests/test_file_libtiff_small.py index 0db37c7ea..2eabc60fd 100644 --- a/Tests/test_file_libtiff_small.py +++ b/Tests/test_file_libtiff_small.py @@ -1,3 +1,5 @@ +from io import BytesIO + from PIL import Image from .test_file_libtiff import LibTiffTestCase @@ -25,8 +27,6 @@ class TestFileLibTiffSmall(LibTiffTestCase): def test_g4_hopper_bytesio(self): """Testing the bytesio loading code path""" - from io import BytesIO - test_file = "Tests/images/hopper_g4.tif" s = BytesIO() with open(test_file, "rb") as f: diff --git a/Tests/test_file_tiff.py b/Tests/test_file_tiff.py index d3e39e8c6..7c133226d 100644 --- a/Tests/test_file_tiff.py +++ b/Tests/test_file_tiff.py @@ -1,4 +1,5 @@ import logging +import os import sys from io import BytesIO @@ -495,10 +496,7 @@ class TestFileTiff(PillowTestCase): self.assert_image_equal(im.convert("RGB"), reloaded.convert("RGB")) def test_tiff_save_all(self): - import io - import os - - mp = io.BytesIO() + mp = BytesIO() with Image.open("Tests/images/multipage.tiff") as im: im.save(mp, format="tiff", save_all=True) @@ -507,7 +505,7 @@ class TestFileTiff(PillowTestCase): self.assertEqual(im.n_frames, 3) # Test appending images - mp = io.BytesIO() + mp = BytesIO() im = Image.new("RGB", (100, 100), "#f00") ims = [Image.new("RGB", (100, 100), color) for color in ["#0f0", "#00f"]] im.copy().save(mp, format="TIFF", save_all=True, append_images=ims) @@ -520,7 +518,7 @@ class TestFileTiff(PillowTestCase): def imGenerator(ims): yield from ims - mp = io.BytesIO() + mp = BytesIO() im.save(mp, format="TIFF", save_all=True, append_images=imGenerator(ims)) mp.seek(0, os.SEEK_SET) @@ -578,7 +576,6 @@ class TestFileTiff(PillowTestCase): class TestFileTiffW32(PillowTestCase): def test_fd_leak(self): tmpfile = self.tempfile("temp.tif") - import os # this is an mmaped file. with Image.open("Tests/images/uint16_1_4660.tif") as im: diff --git a/Tests/test_file_webp_metadata.py b/Tests/test_file_webp_metadata.py index 39d6f30c4..2361cc51c 100644 --- a/Tests/test_file_webp_metadata.py +++ b/Tests/test_file_webp_metadata.py @@ -1,3 +1,5 @@ +from io import BytesIO + from PIL import Image from .helper import PillowTestCase @@ -39,8 +41,6 @@ class TestFileWebpMetadata(PillowTestCase): self.assertEqual(exif_data, expected_exif) def test_write_exif_metadata(self): - from io import BytesIO - file_path = "Tests/images/flower.jpg" image = Image.open(file_path) expected_exif = image.info["exif"] @@ -73,8 +73,6 @@ class TestFileWebpMetadata(PillowTestCase): self.assertEqual(icc, expected_icc) def test_write_icc_metadata(self): - from io import BytesIO - file_path = "Tests/images/flower2.jpg" image = Image.open(file_path) expected_icc_profile = image.info["icc_profile"] @@ -95,8 +93,6 @@ class TestFileWebpMetadata(PillowTestCase): ) def test_read_no_exif(self): - from io import BytesIO - file_path = "Tests/images/flower.jpg" image = Image.open(file_path) self.assertIn("exif", image.info) diff --git a/Tests/test_file_xbm.py b/Tests/test_file_xbm.py index 9693ba05a..3d2259a21 100644 --- a/Tests/test_file_xbm.py +++ b/Tests/test_file_xbm.py @@ -1,3 +1,5 @@ +from io import BytesIO + from PIL import Image from .helper import PillowTestCase @@ -28,8 +30,6 @@ static char basic_bits[] = { class TestFileXbm(PillowTestCase): def test_pil151(self): - from io import BytesIO - im = Image.open(BytesIO(PIL151)) im.load() diff --git a/Tests/test_image.py b/Tests/test_image.py index 75b5e778a..dc87a1e37 100644 --- a/Tests/test_image.py +++ b/Tests/test_image.py @@ -1,6 +1,7 @@ import os import shutil import sys +import tempfile from PIL import Image @@ -119,8 +120,6 @@ class TestImage(PillowTestCase): def test_tempfile(self): # see #1460, pathlib support breaks tempfile.TemporaryFile on py27 # Will error out on save on 3.0.0 - import tempfile - im = hopper() with tempfile.TemporaryFile() as fp: im.save(fp, "JPEG") diff --git a/Tests/test_image_access.py b/Tests/test_image_access.py index a15a8b75e..144b91bac 100644 --- a/Tests/test_image_access.py +++ b/Tests/test_image_access.py @@ -1,5 +1,8 @@ +import ctypes import os +import subprocess import sys +from distutils import ccompiler, sysconfig from PIL import Image @@ -337,10 +340,6 @@ class TestEmbeddable(unittest.TestCase): "Failing on AppVeyor when run from subprocess, not from shell", ) def test_embeddable(self): - import subprocess - import ctypes - from distutils import ccompiler, sysconfig - with open("embed_pil.c", "w") as fh: fh.write( """ diff --git a/src/PIL/EpsImagePlugin.py b/src/PIL/EpsImagePlugin.py index badeef4ed..6d85da988 100644 --- a/src/PIL/EpsImagePlugin.py +++ b/src/PIL/EpsImagePlugin.py @@ -23,7 +23,9 @@ import io import os import re +import subprocess import sys +import tempfile from . import Image, ImageFile from ._binary import i32le as i32 @@ -54,8 +56,6 @@ def has_ghostscript(): if gs_windows_binary: return True if not sys.platform.startswith("win"): - import subprocess - try: with open(os.devnull, "wb") as devnull: subprocess.check_call(["gs", "--version"], stdout=devnull) @@ -84,9 +84,6 @@ def Ghostscript(tile, size, fp, scale=1): float((72.0 * size[1]) / (bbox[3] - bbox[1])), ) - import subprocess - import tempfile - out_fd, outfile = tempfile.mkstemp() os.close(out_fd) diff --git a/src/PIL/GifImagePlugin.py b/src/PIL/GifImagePlugin.py index 69ff2f66a..2024e025d 100644 --- a/src/PIL/GifImagePlugin.py +++ b/src/PIL/GifImagePlugin.py @@ -25,6 +25,8 @@ # import itertools +import os +import subprocess from . import Image, ImageChops, ImageFile, ImagePalette, ImageSequence from ._binary import i8, i16le as i16, o8, o16le as o16 @@ -617,24 +619,22 @@ def _save_netpbm(im, fp, filename): # If you need real GIF compression and/or RGB quantization, you # can use the external NETPBM/PBMPLUS utilities. See comments # below for information on how to enable this. - - import os - from subprocess import Popen, check_call, PIPE, CalledProcessError - tempfile = im._dump() with open(filename, "wb") as f: if im.mode != "RGB": with open(os.devnull, "wb") as devnull: - check_call(["ppmtogif", tempfile], stdout=f, stderr=devnull) + subprocess.check_call(["ppmtogif", tempfile], stdout=f, stderr=devnull) else: # Pipe ppmquant output into ppmtogif # "ppmquant 256 %s | ppmtogif > %s" % (tempfile, filename) quant_cmd = ["ppmquant", "256", tempfile] togif_cmd = ["ppmtogif"] with open(os.devnull, "wb") as devnull: - quant_proc = Popen(quant_cmd, stdout=PIPE, stderr=devnull) - togif_proc = Popen( + quant_proc = subprocess.Popen( + quant_cmd, stdout=subprocess.PIPE, stderr=devnull + ) + togif_proc = subprocess.Popen( togif_cmd, stdin=quant_proc.stdout, stdout=f, stderr=devnull ) @@ -643,11 +643,11 @@ def _save_netpbm(im, fp, filename): retcode = quant_proc.wait() if retcode: - raise CalledProcessError(retcode, quant_cmd) + raise subprocess.CalledProcessError(retcode, quant_cmd) retcode = togif_proc.wait() if retcode: - raise CalledProcessError(retcode, togif_cmd) + raise subprocess.CalledProcessError(retcode, togif_cmd) try: os.unlink(tempfile) diff --git a/src/PIL/IcnsImagePlugin.py b/src/PIL/IcnsImagePlugin.py index 03484cf0e..efa7f3c2b 100644 --- a/src/PIL/IcnsImagePlugin.py +++ b/src/PIL/IcnsImagePlugin.py @@ -19,6 +19,7 @@ import io import os import shutil import struct +import subprocess import sys import tempfile @@ -333,11 +334,12 @@ def _save(im, fp, filename): last_w = w * 2 # iconutil -c icns -o {} {} - from subprocess import Popen, PIPE, CalledProcessError convert_cmd = ["iconutil", "-c", "icns", "-o", filename, iconset] with open(os.devnull, "wb") as devnull: - convert_proc = Popen(convert_cmd, stdout=PIPE, stderr=devnull) + convert_proc = subprocess.Popen( + convert_cmd, stdout=subprocess.PIPE, stderr=devnull + ) convert_proc.stdout.close() @@ -347,7 +349,7 @@ def _save(im, fp, filename): shutil.rmtree(iconset) if retcode: - raise CalledProcessError(retcode, convert_cmd) + raise subprocess.CalledProcessError(retcode, convert_cmd) Image.register_open(IcnsImageFile.format, IcnsImageFile, lambda x: x[:4] == b"icns") diff --git a/src/PIL/Image.py b/src/PIL/Image.py index 026b04491..494be337a 100644 --- a/src/PIL/Image.py +++ b/src/PIL/Image.py @@ -33,6 +33,7 @@ import numbers import os import struct import sys +import tempfile import warnings from collections.abc import Callable, MutableMapping from pathlib import Path @@ -612,8 +613,6 @@ class Image: self.load() def _dump(self, file=None, format=None, **options): - import tempfile - suffix = "" if format: suffix = "." + format diff --git a/src/PIL/ImageFont.py b/src/PIL/ImageFont.py index f1bd6242a..619800829 100644 --- a/src/PIL/ImageFont.py +++ b/src/PIL/ImageFont.py @@ -25,8 +25,10 @@ # See the README file for information on usage and redistribution. # +import base64 import os import sys +from io import BytesIO from . import Image from ._util import isDirectory, isPath @@ -710,9 +712,6 @@ def load_default(): :return: A font object. """ - from io import BytesIO - import base64 - f = ImageFont() f._load_pilfont_data( # courB08 diff --git a/src/PIL/ImageGrab.py b/src/PIL/ImageGrab.py index 9b4413536..e587d942d 100644 --- a/src/PIL/ImageGrab.py +++ b/src/PIL/ImageGrab.py @@ -15,17 +15,14 @@ # See the README file for information on usage and redistribution. # +import os +import subprocess import sys +import tempfile from . import Image -if sys.platform == "win32": - grabber = Image.core.grabscreen -elif sys.platform == "darwin": - import os - import tempfile - import subprocess -else: +if sys.platform not in ["win32", "darwin"]: raise ImportError("ImageGrab is macOS and Windows only") @@ -40,7 +37,7 @@ def grab(bbox=None, include_layered_windows=False, all_screens=False): if bbox: im = im.crop(bbox) else: - offset, size, data = grabber(include_layered_windows, all_screens) + offset, size, data = Image.core.grabscreen(include_layered_windows, all_screens) im = Image.frombytes( "RGB", size, diff --git a/src/PIL/JpegImagePlugin.py b/src/PIL/JpegImagePlugin.py index 8c88a94c4..22ec5ceb9 100644 --- a/src/PIL/JpegImagePlugin.py +++ b/src/PIL/JpegImagePlugin.py @@ -33,7 +33,10 @@ # import array import io +import os import struct +import subprocess +import tempfile import warnings from . import Image, ImageFile, TiffImagePlugin @@ -441,10 +444,6 @@ class JpegImageFile(ImageFile.ImageFile): # ALTERNATIVE: handle JPEGs via the IJG command line utilities - import subprocess - import tempfile - import os - f, path = tempfile.mkstemp() os.close(f) if os.path.exists(self.filename): @@ -769,9 +768,6 @@ def _save(im, fp, filename): def _save_cjpeg(im, fp, filename): # ALTERNATIVE: handle JPEGs via the IJG command line utilities. - import os - import subprocess - tempfile = im._dump() subprocess.check_call(["cjpeg", "-outfile", filename, tempfile]) try: