builtins.TypeError: debe ser str, no bytes


220

He convertido mis scripts de Python 2.7 a 3.2, y tengo un error.

# -*- coding: utf-8 -*-
import time
from datetime import date
from lxml import etree
from collections import OrderedDict

# Create the root element
page = etree.Element('results')

# Make a new document tree
doc = etree.ElementTree(page)

# Add the subelements
pageElement = etree.SubElement(page, 'Country',Tim = 'Now', 
                                      name='Germany', AnotherParameter = 'Bye',
                                      Code='DE',
                                      Storage='Basic')
pageElement = etree.SubElement(page, 'City', 
                                      name='Germany',
                                      Code='PZ',
                                      Storage='Basic',AnotherParameter = 'Hello')
# For multiple multiple attributes, use as shown above

# Save to XML file
outFile = open('output.xml', 'w')
doc.write(outFile) 

En la última línea, recibí este error:

builtins.TypeError: must be str, not bytes
File "C:\PythonExamples\XmlReportGeneratorExample.py", line 29, in <module>
  doc.write(outFile)
File "c:\Python32\Lib\site-packages\lxml\etree.pyd", line 1853, in lxml.etree._ElementTree.write (src/lxml/lxml.etree.c:44355)
File "c:\Python32\Lib\site-packages\lxml\etree.pyd", line 478, in lxml.etree._tofilelike (src/lxml/lxml.etree.c:90649)
File "c:\Python32\Lib\site-packages\lxml\etree.pyd", line 282, in lxml.etree._ExceptionContext._raise_if_stored (src/lxml/lxml.etree.c:7972)
File "c:\Python32\Lib\site-packages\lxml\etree.pyd", line 378, in lxml.etree._FilelikeWriter.write (src/lxml/lxml.etree.c:89527)

Instalé Python 3.2 y lxml-2.3.win32-py3.2.exe.

En Python 2.7 funciona.


10
Realmente no investigé esto, pero una suposición rápida es que debe abrir el archivo en modo binario.
Sven Marnach

Respuestas:


484

El archivo de salida debe estar en modo binario.

outFile = open('output.xml', 'wb')

100
Mente alucinada. Python3 ha reinventado qué hacer con esa pequeña 'b'. Solía ​​molestar a los usuarios de Windows que olvidaban incluirlo (o no podían porque estaban usando stdio). Ahora puede molestar a los usuarios de Python en todas las plataformas. Con suerte, valdrá la pena.
nobar

55
Si está analizando texto definitivamente vale la pena.
Lennart Regebro

@nobar Es necesario, por ejemplo, desactivar el soporte universal de nueva línea, legacy.python.org/dev/peps/pep-0278 , que está activado de forma predeterminada en Python 3
user7610

¡También funciona para mí en gzip para python3! json.load(gzip.open('file.json.gz'))falla y json.load(gzip.open('file.json.gz', 'rt'))tiene éxito!
placas el

@LennartRegebro, no si la configuración del sistema es inesperada. Binario es mejor y menos propenso a errores. Si funciona, realmente funciona. En cuanto al texto, siempre hay un "qué pasaría si" involucrado.
Pacerier

6

Convierte archivos binarios a base64 y viceversa. Probar en python 3.5.2

import base64

read_file = open('/tmp/newgalax.png', 'rb')
data = read_file.read()

b64 = base64.b64encode(data)

print (b64)

# Save file
decode_b64 = base64.b64decode(b64)
out_file = open('/tmp/out_newgalax.png', 'wb')
out_file.write(decode_b64)

# Test in python 3.5.2
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.