ImportError: No module named ‘Image’の対応-Python2系から3系への移行


AWS環境で、Python2系・Django1.6で動いているアプリをPython3系(3.4.3)、Django1.8で動かそうとした時に出たエラーのメモ。

Traceback (most recent call last):
File "manage.py", line 10, in
execute_from_command_line(sys.argv)
File "/usr/local/lib/python3.4/site-packages/django/core/management/__init__.py", line 338, in execute_from_command_line
utility.execute()
File "/usr/local/lib/python3.4/site-packages/django/core/management/__init__.py", line 312, in execute
django.setup()
File "/usr/local/lib/python3.4/site-packages/django/__init__.py", line 18, in setup
apps.populate(settings.INSTALLED_APPS)
File "/usr/local/lib/python3.4/site-packages/django/apps/registry.py", line 108, in populate
app_config.import_models(all_models)
File "/usr/local/lib/python3.4/site-packages/django/apps/config.py", line 198, in import_models
self.models_module = import_module(models_module_name)
File "/usr/local/lib/python3.4/importlib/__init__.py", line 109, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "", line 2254, in _gcd_import
File "", line 2237, in _find_and_load
File "", line 2226, in _find_and_load_unlocked
File "", line 1200, in _load_unlocked
File "", line 1129, in _exec
File "", line 1471, in exec_module
File "", line 321, in _call_with_frames_removed
File "/home/ec2-user/xxxx/xxxx/xxxx/models.py", line 8, in
import Image
ImportError: No module named 'Image'

Imageというモジュールがないというエラー。

これは、
import Image
となっている部分を
from PIL import Image
に変更したところ解消された。

元のコード部分を残しておくため該当のmodels.pyの冒頭部分の該当箇所を以下のように修正した。
from PIL import Image
#import Image

上記でエラーは解消された。

PILがPillowにフォークされて変化したものと思われます。

参考ページ:pygame – Python 3.3 with Pillow – ImportError: No module named ‘Image’ – Stack Overflow