我试图向JPG文件的IPTC数据添加关键字,但失败了。我能够使用iptcinfo3库读取关键字,并似乎将关键字附加到当前关键字列表中,但当我尝试将这些关键字写回JPG文件时(如果不是更早的话),我失败了。错误消息对我来说有点不清楚,实际上可能涉及新关键字的附加(尽管打印语句似乎表明已经成功)。
我尝试了三个不同的元数据库(似乎没有标准),并且这是我使用它们中任何一个所达到的最远进展(其中一个甚至无法安装,另一个无法运行)。这看起来很基础,但我想不出来,也无法适应我在网上看到的少数其他代码示例,包括iptcinfo3的示例代码片段。
当前的错误消息是:
我尝试了三个不同的元数据库(似乎没有标准),并且这是我使用它们中任何一个所达到的最远进展(其中一个甚至无法安装,另一个无法运行)。这看起来很基础,但我想不出来,也无法适应我在网上看到的少数其他代码示例,包括iptcinfo3的示例代码片段。
当前的错误消息是:
| => pipenv run python editMetadata.py
WARNING: problems with charset recognition (b'\x1b')
[b'Gus']
[b'Gus', b'frog']
Traceback (most recent call last):
File "editMetadata.py", line 22, in <module>
info.save_as('Gus2.jpg')
File "/Users/Scott/.local/share/virtualenvs/editPhotoMetadata-tx0JAOmI/lib/python3.7/site-packages/iptcinfo3.py", line 635, in save_as
jpeg_parts = jpeg_collect_file_parts(fh)
File "/Users/Scott/.local/share/virtualenvs/editPhotoMetadata-tx0JAOmI/lib/python3.7/site-packages/iptcinfo3.py", line 324, in jpeg_collect_file_parts
adobeParts = collect_adobe_parts(partdata)
File "/Users/Scott/.local/share/virtualenvs/editPhotoMetadata-tx0JAOmI/lib/python3.7/site-packages/iptcinfo3.py", line 433, in collect_adobe_parts
out = [''.join(out)]
TypeError: sequence item 0: expected str instance, bytes found
代码:
from iptcinfo3 import IPTCInfo
import os
# Create new info object
info = IPTCInfo('Gus.jpg')
# Print list of keywords
print(info['keywords'])
# Append the keyword I want to add
info['keywords'].append(b'frog')
# Print to test keyword has been added
print(info['keywords'])
# Save new info to file
info.save()
info.save_as('Gus2.jpg')