How to work around a unicode problem?

tinnews at isbd.co.uk tinnews at isbd.co.uk
Tue Jan 24 12:23:37 EST 2012


Chris Rebert <clp2 at rebertia.com> wrote:
> On Tue, Jan 24, 2012 at 3:57 AM,  <tinnews at isbd.co.uk> wrote:
> > I have a small python program that uses the pyexiv2 package to view
> > exif data in image files.
> >
> > I've hit a problem because I have a filename with accented characters
> > in its path and the pyexiv2 code traps as follows:-
> >
> >    Traceback (most recent call last):
> >      File "/home/chris/bin/eview.py", line 87, in <module>
> >        image = pyexiv2.ImageMetadata(filepath)
> >      File "/usr/lib/python2.7/dist-packages/pyexiv2/metadata.py", line 65, in __init__
> >        self.filename = filename.encode(sys.getfilesystemencoding())
> >    UnicodeDecodeError: 'ascii' codec can't decode byte 0xc3 in position 38: ordinal not in range(128)
> >
> > Without digging deep into pyexiv2 is there any way I can work around
> > this error?  The accented characters aren't in the filename itself,
> > they're in the directory path.
> 
> After glancing at the docs, (untested):
> 
> with open(filepath) as f:
>     image = pyexiv2.ImageMetadata.from_buffer(f.read())
> 
Excellent, worked perfectly (after I spotted I had another variable f).

Thank you.

-- 
Chris Green



More information about the Python-list mailing list