<table cellspacing="0" cellpadding="0" border="0" ><tr><td valign="top" style="font: inherit;">Hola, el mensaje de error es el que figura en el título de email:<br><br>'int' does not support the buffer interface<br><br>Fíjate que tengo un if(cur) dentro del finally de esa forma solo se ejecuta cuando es necesario.<br><br>Un saludo.<br><br>--- On <b>Mon, 2/21/11, Eduard Diaz <i>&lt;eventgrafic@gmail.com&gt;</i></b> wrote:<br><blockquote style="border-left: 2px solid rgb(16, 16, 255); margin-left: 5px; padding-left: 5px;"><br>From: Eduard Diaz &lt;eventgrafic@gmail.com&gt;<br>Subject: Re: [Python-es] 'int' does not support the buffer interface<br>To: "La lista de python en castellano" &lt;python-es@python.org&gt;<br>Date: Monday, February 21, 2011, 7:31 PM<br><br><div id="yiv429754016">Hola,<br><br>¿Primero de todo puedes enviar la cadena "mesaje del fallo: " + str(errr) para ver que tipo de excepción devuelve?, ¿es siempre el
 mismo?<br><br>Normalmente la clausula finally se utiliza para liberar recursos independientemente de si se ha producido o no una excepción, por lo que no es recomendable hacer el commit en ella. <br>
<br>Quizas sea mejor hacer una secuencia tipo: try, excerpt, else (con el commit) y finally (para cerrar el cursor si lo creas dentro de la función) sobretodo con tantas inserciones.<br><br>Un saludo<br>
<br><div class="yiv429754016gmail_quote">El 21 de febrero de 2011 19:45, Spectrum Cuarenta y ocho k <span dir="ltr">&lt;<a rel="nofollow" ymailto="mailto:s_48k@yahoo.com" target="_blank" href="/mc/compose?to=s_48k@yahoo.com">s_48k@yahoo.com</a>&gt;</span> escribió:<br><blockquote class="yiv429754016gmail_quote" style="margin:0pt 0pt 0pt 0.8ex;border-left:1px solid rgb(204, 204, 204);padding-left:1ex;">

<table border="0" cellpadding="0" cellspacing="0"><tbody><tr><td style="font:inherit;" valign="top">Hola Gerardo. <br>Si uso MySql. Había puesto el commit por cada registro para que si había algún fallo, por lo menos, tener guardado lo que iba pasando a la base de datos y no perderlo todo. Pero apunto el tema de ponerlo al final, para que haga todos los registros a la vez y mejorar el rendimiento.<br>

<br>En cuanto al módulo Mysqldb, me pareció entender que no había para python 3, por eso usé PyMySQL. Y como bien dices, es posible que sea un fallo del módulo.<br><br>Gracias y un saludo.<div><br><br>--- On <b>Mon, 2/21/11, gerardo Juarez <i>&lt;<a rel="nofollow" ymailto="mailto:gerardojuarez@buyteknet.info" target="_blank" href="/mc/compose?to=gerardojuarez@buyteknet.info">gerardojuarez@buyteknet.info</a>&gt;</i></b> wrote:<br>

</div><blockquote style="border-left:2px solid rgb(16, 16, 255);margin-left:5px;padding-left:5px;"><div><br>From: gerardo Juarez &lt;<a rel="nofollow" ymailto="mailto:gerardojuarez@buyteknet.info" target="_blank" href="/mc/compose?to=gerardojuarez@buyteknet.info">gerardojuarez@buyteknet.info</a>&gt;<br>

</div><div>Subject: Re: [Python-es] 'int' does not support the buffer interface<br>To: "La lista de python en
 castellano" &lt;<a rel="nofollow" ymailto="mailto:python-es@python.org" target="_blank" href="/mc/compose?to=python-es@python.org">python-es@python.org</a>&gt;<br></div>Date: Monday, February 21, 2011, 6:17 PM<div><div></div><div><br><br><div>No me había fijado que el commit lo hace por cada registro. Por&nbsp; lo que nos describe, la tarea que se ejecuta para procesar unos 20000 registros parece ser una tarea 'batch'. Como tal, sería mejor tal vez procesar todos los registros y hasta el final aplicar el commit(), de lo contrario es como sugiere Miguel aquí abajo, de mejor poner la base en autocommit(). Claro, esto hará que se tarde muchísimo, en comparación de aplicar el commit al final.<br>

<br>Por otra parte, no sé si siquiera el commit() esté haciendo algo, porque (está usando Mysql correcto?) entonces el 'storage-engine' por omisión es MyISAM y éste no tiene transacciones, por lo cual permite pero ignora silenciosamente los 'commits'. Para poder usarlo, debería estar la tabla en cuestión almacenada con InnoDb, y la base en un modo que sea distinto de autocommit.
 Entonces sí tendría sentido el commit y creo que debería ser al final de los 20000 registros y no con cada uno, salvo un requerimiento muy especial que no conocemos.<br><br>Otra posibilidad es que está usando PyMysql, que es un módulo relativamente nuevo. No convendría probar con Mysqldb, que es ya muy estable y ver si el error se repite? Igual hay que reportar un problema.<br>

<br>saludos<br>Gerardo<br><br>miguel zamora m. wrote:<br>&gt; debes de usar el metodo refresh para los datos si la base se bloquea no podras insertar nada<br>&gt; ademas usa algo asi<br>&gt; self.con.autocommit(True)<br>
&gt; <br>
&gt; <br>&gt; <br>&gt; El 21 de febrero de 2011 09:40, Spectrum Cuarenta y ocho k &lt;<a rel="nofollow" target="_blank" href="http://mc/compose?to=s_48k@yahoo.com">s_48k@yahoo.com</a> &lt;mailto:<a rel="nofollow" target="_blank" href="http://mc/compose?to=s_48k@yahoo.com">s_48k@yahoo.com</a>&gt;&gt; escribió:<br>

&gt; <br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;Hola
 gente, he hecho un programa para insertar registros en una<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;BD. Son bastantes, y lo estoy haciendo por tramos de 20.000 más o<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;menos (de forma individual, vamos que hago correr el script cada<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;20000). El caso, es que funciona bastante bien, pero cuando llevo<br>

&gt;&nbsp; &nbsp;&nbsp;&nbsp;3 o 4 partes, sigue funcionando... pero se salta el try. Me<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;explico, inserta el registro,imprime el OK, pero también me<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;ejecuta lo que está dentro del try y pone este error: 'int' does<br>

&gt;&nbsp; &nbsp;&nbsp;&nbsp;not support the buffer interface.<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;Por lo tanto, sigue realizando su función pero enseña el error. Si<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;reinicio el ordenador y vuelvo a ejecutarlo (exactamente el mismo<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;código) ya no da el error. Me da
 la impresión que es algún buffer<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;de python.<br>&gt; <br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;¿a alguien le suena algo de esto o parecido?<br>&gt; <br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;Venga, un saludo.<br>&gt; <br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;def insertar(autor, texto):<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;query = "INSERT INTO famous_quote (text, author) VALUES<br>

&gt;&nbsp; &nbsp;&nbsp;&nbsp;(\"%s\", \"%s\")" % (texto, autor)<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;curs = conn.cursor()<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;try:<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;curs.execute(query)<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;except Exception as errr:<br>

&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;print("mesaje del fallo: " + str(errr))<br>&gt;&nbsp; &nbsp;
 &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;print("Fallo en: " + query)<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;pass<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;finally:<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;if(curs):<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;curs.close()<br>&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;conn.commit()<br>

&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&nbsp;&nbsp;print("OK!")<br>&gt; <br>&gt; <br>&gt; <br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;_______________________________________________<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;Python-es mailing list<br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;<a rel="nofollow" target="_blank" href="http://mc/compose?to=Python-es@python.org">Python-es@python.org</a> &lt;mailto:<a rel="nofollow" target="_blank" href="http://mc/compose?to=Python-es@python.org">Python-es@python.org</a>&gt;<br>

&gt;&nbsp; &nbsp;&nbsp;&nbsp;<a rel="nofollow" target="_blank" href="http://mail.python.org/mailman/listinfo/python-es">http://mail.python.org/mailman/listinfo/python-es</a><br>&gt;&nbsp; &nbsp;&nbsp;&nbsp;FAQ: <a rel="nofollow" target="_blank" href="http://python-es-faq.wikidot.com/">http://python-es-faq.wikidot.com/</a><br>

&gt; <br>&gt; <br>&gt; <br>&gt; <br>&gt; -- Miguel Zamora M.<br>&gt; Programador en Computacion e Informatica<br>&gt; 08-1351249<br>&gt; <a rel="nofollow" target="_blank" href="http://mc/compose?to=mzmprog@gmail.com">mzmprog@gmail.com</a> &lt;mailto:<a rel="nofollow" target="_blank" href="http://mc/compose?to=mzmprog@gmail.com">mzmprog@gmail.com</a>&gt;<br>

&gt; Santiago-Chile<br>&gt; <br>&gt;
 ------------------------------------------------------------------------<br>&gt; <br>&gt; _______________________________________________<br>&gt; Python-es mailing list<br>&gt; <a rel="nofollow" target="_blank" href="http://mc/compose?to=Python-es@python.org">Python-es@python.org</a><br>

&gt; <a rel="nofollow" target="_blank" href="http://mail.python.org/mailman/listinfo/python-es">http://mail.python.org/mailman/listinfo/python-es</a><br>&gt; FAQ: <a rel="nofollow" target="_blank" href="http://python-es-faq.wikidot.com/">http://python-es-faq.wikidot.com/</a><br>

&gt;&nbsp;&nbsp;&nbsp;<br><br>_______________________________________________<br>Python-es mailing list<br><a rel="nofollow" target="_blank" href="http://mc/compose?to=Python-es@python.org">Python-es@python.org</a><br><a rel="nofollow" target="_blank" href="http://mail.python.org/mailman/listinfo/python-es">http://mail.python.org/mailman/listinfo/python-es</a><br>

FAQ: <a rel="nofollow" target="_blank" href="http://python-es-faq.wikidot.com/">http://python-es-faq.wikidot.com/</a><br></div></div></div></blockquote></td></tr></tbody></table><br>

      <br>_______________________________________________<br>
Python-es mailing list<br>
<a rel="nofollow" ymailto="mailto:Python-es@python.org" target="_blank" href="/mc/compose?to=Python-es@python.org">Python-es@python.org</a><br>
<a rel="nofollow" target="_blank" href="http://mail.python.org/mailman/listinfo/python-es">http://mail.python.org/mailman/listinfo/python-es</a><br>
FAQ: <a rel="nofollow" target="_blank" href="http://python-es-faq.wikidot.com/">http://python-es-faq.wikidot.com/</a><br>
<br></blockquote></div><br><br clear="all"><br>-- <br>//////////////////////////////////////////////////////////////////////////<br>Eduard Díaz<br><a rel="nofollow" target="_blank" href="http://www.scopia.es">www.scopia.es</a><br>SCOPIA VISUAL INTERFACES SYSTEMS S.L.<br>

Barcelona<br>Tel. 625 055 126, 933 171 771<br>//////////////////////////////////////////////////////////////////////////<br>
</div><br>-----Inline Attachment Follows-----<br><br><div class="plainMail">_______________________________________________<br>Python-es mailing list<br><a ymailto="mailto:Python-es@python.org" href="/mc/compose?to=Python-es@python.org">Python-es@python.org</a><br><a href="http://mail.python.org/mailman/listinfo/python-es" target="_blank">http://mail.python.org/mailman/listinfo/python-es</a><br>FAQ: <a href="http://python-es-faq.wikidot.com/" target="_blank">http://python-es-faq.wikidot.com/</a><br></div></blockquote></td></tr></table><br>