Python:TIFFReadDirectory警告:带标记的未知字段

2024-09-29 01:30:10 发布

您现在位置:Python中文网/ 问答频道 /正文

问题
我可以用kivy中的Image()模块加载图片。This是我如何安装kivy以便查看TIFF文件的。但是现在每次我加载一个TIFF图像,我都会收到一个接一个的弹出警告,打断程序。你知道吗

TIFFReadDirectory warning:
unknown field with tag 18246 (0x4746)
TIFFReadDirectory warning:
unknown field with tag 18249 (0x4749)
TIFFReadDirectory warning:
unknown field with tag 20752 (0x5110)
TIFFReadDirectory warning:
unknown field with tag 20753 (0x5111)
TIFFReadDirectory warning:
unknown field with tag 20754 (0x5112)
TIFFReadDirectory warning:
unknown field with tag 40092 (0x9c9c)
TIFFReadDirectory warning:
unknown field with tag 40093 (0x9c9d)
TIFFReadDirectory warning:
unknown field with tag 40094 (0x9c9e)

为了澄清,这些警告都不会出现在python日志中。这些都是在我的程序显示TIFF文件之前出现的单独警告框。我听说一个叫libtiff的库会引起这个问题。你知道吗

代码

from kivy.app import App
from kivy.uix.boxlayout import BoxLayout
from kivy.clock import Clock
from kivy.uix.image import Image

class ContainerBox(BoxLayout):
    def __init__(self, **kwargs):
        super(ContainerBox, self).__init__(**kwargs)
        self.orientation = 'vertical'
        self.picture = Image(allow_stretch=True, source='..\pics\snorlax.tif')
        Clock.schedule_once(lambda dt: self.add_widget(self.picture), timeout=0.1)


class SimpleImage(App):
    def build(self):
        return ContainerBox()

if __name__ == '__main__':
    SimpleImage().run()

技术细节

  • 图片可以下载here。你知道吗
  • 我已经修改了这个文件的exif数据。可能是我在文件中添加了几个非标准标记。但是我对jpg文件和png文件也做了同样的事情。这些并没有引起像这样恼人的弹出窗口。你知道吗
  • 我使用的是Kivy版本1.11.1
  • 根据Anaconda的说法,虚拟环境运行的是python3.5.6
  • 我正在Windows7上通过PyCharm运行这个
  • 以下是python日志中的详细信息:
[INFO   ] [deps        ] Successfully imported "kivy_deps.glew" 0.1.12
[INFO   ] [deps        ] Successfully imported "kivy_deps.sdl2" 0.1.22
[INFO   ] [Kivy        ] v1.11.1
[INFO   ] [Kivy        ] Installed at "C:\Users\H\venvs\env1\lib\site-packages\kivy\__init__.py"
[INFO   ] [Python      ] v3.6.0 (v3.6.0:41df79263a11, Dec 23 2016, 08:06:12) [MSC v.1900 64 bit (AMD64)]
[INFO   ] [Python      ] Interpreter at "C:\Users\H\venvs\env1\Scripts\python.exe"
[INFO   ] [Factory     ] 184 symbols loaded
[INFO   ] [Image       ] Providers: img_tex, img_dds, img_sdl2, img_gif (img_pil, img_ffpyplayer ignored)
[INFO   ] [Loader      ] using a thread pool of 2 workers
[INFO   ] [Text        ] Provider: sdl2
[INFO   ] [Window      ] Provider: sdl2
[INFO   ] [GL          ] Using the "OpenGL" graphics system
[INFO   ] [GL          ] Backend used <sdl2>
[INFO   ] [GL          ] OpenGL version <b'4.0.0 - Build 9.18.10.3204'>
[INFO   ] [GL          ] OpenGL vendor <b'Intel'>
[INFO   ] [GL          ] OpenGL renderer <b'Intel(R) HD Graphics 4600'>
[INFO   ] [GL          ] OpenGL parsed version: 4, 0
[INFO   ] [GL          ] Shading version <b'4.00 - Build 9.18.10.3204'>
[INFO   ] [GL          ] Texture max size <8192>
[INFO   ] [GL          ] Texture max units <16>
[INFO   ] [Window      ] auto add sdl2 input provider

我的问题 是否可以抑制这些警告?我认为它们是由kivy调用的某个库生成的。它甚至可能是我无法编辑的预编译代码。
我花了很长时间用Kivy制作了一个复杂的用户界面。我真的不想放弃所有的工作。但我可能愿意把它移植到c++中,理论上我可以控制更多的代码。这是必要的还是可能的?你知道吗


Tags: 文件imageselfinfofieldimgtagwith
1条回答
网友
1楼 · 发布于 2024-09-29 01:30:10

在我的剧本开头,我加了

import ctypes

libbytiff = ctypes.CDLL("libtiff-5.dll")
libbytiff.TIFFSetWarningHandler.argtypes = [ctypes.c_void_p]
libbytiff.TIFFSetWarningHandler.restype = ctypes.c_void_p
libbytiff.TIFFSetWarningHandler(None)

警告停止了。你知道吗

相关问题 更多 >