2012-02-24 13 views
1

私はsqliteのにXMLを変換し、奇妙なエラーを取得しようとしている:ライン130は、ここで全体のコードPyQtは、SQLAlchemyの - 奇妙な挿入クラッシュ

t_id = select([tb_temperatures.c.id], tb_temperatures.c.temperature == temp) 

に対応

Traceback (most recent call last): 
File "C:\Temp\xxx\scripts\xml_to_db.py", line 212, in <module> 
win = Test(a) 
File "C:\Temp\xxx\scripts\xml_to_db.py", line 20, in __init__ 
self.testdb() 
File "C:\Temp\xxx\scripts\xml_to_db.py", line 133, in testdb 
row = connection.execute(t_id) 
File "C:\Temp\PortablePython\App\lib\site-packages\sqlalchemy\engine\base.py", line 1405, in execute 
params) 
File "C:\Temp\PortablePython\App\lib\site-packages\sqlalchemy\engine\base.py", line 1538, in _execute_clause 
element 
compiled_sql, distilled_params 
File "C:\Temp\PortablePython\App\lib\site-packages\sqlalchemy\engine\base.py", line 1646, in _execute_context 
context) 
File "C:\Temp\PortablePython\App\lib\site-packages\sqlalchemy\engine\base.py", line 1639, in _execute_context 
context) 
File "C:\Temp\PortablePython\App\lib\site-packages\sqlalchemy\engine\default.py", line 330, in do_execute 
cursor.execute(statement, parameters) 
InterfaceError: (InterfaceError) Error binding parameter 0 - probably unsupported type. u'SELECT temperatures.id \nFROM temperatures \nWHERE temperatures.temperature = ?' ('50',) 

def testdb(self): 
    db_file = "C:/Temp/xxx/data/xxx/db.sqlite" 

    file=QFile(db_file) 
    if file.exists(): 
     file.remove() 

    db = create_engine('sqlite:///' + db_file) 
    connection = db.connect() 

    metadata = MetaData() 

    tb_materials = Table('materials', metadata, 
     Column('id', Integer, primary_key=True), 
     Column('material', String) 
     ) 

    tb_temperatures = Table('temperatures', metadata, 
     Column('id', Integer, primary_key=True), 
     Column('temperature', String) 
     ) 

    tb_mat_data = Table('mat_data', metadata, 
     Column('id', Integer, primary_key=True), 
     Column('mat_id', None, ForeignKey('materials.id', onupdate="CASCADE", ondelete="CASCADE")), 
     Column('temp_id', None, ForeignKey('temperatures.id', onupdate="CASCADE", ondelete="CASCADE")), 
     Column('density', String), 
     Column('elasticity', String), 
     Column('stress', String) 
     ) 

    auto_assign(metadata, db) 
    metadata.create_all(db) 

    for m in ['SS 316']: 
     data = tb_materials.insert().values(material = m) 
     connection.execute(data) 

    for t in ['25', '38', '50', '150']: 
     data = tb_temperatures.insert().values(temperature = t) 
     connection.execute(data) 

    materials = ['SS 316'] 
    for material in materials: 
     m_id = select([tb_materials.c.id], tb_materials.c.material == material) 
     row = connection.execute(m_id) 
     data = row.fetchone() 
     m_id_key = data[0] 
     temps = ['25', '38', '50', '150'] 
     for temp in temps: 
      QMessageBox.about(self,"",temp) 
      t_id = select([tb_temperatures.c.id], tb_temperatures.c.temperature == temp) 
      row = connection.execute(t_id) 
      data = row.fetchone() 
      t_id_key = data[0] 
      z = tb_mat_data.insert().values(mat_id = m_id_key, temp_id = t_id_key) 
      connection.execute(z) 

    connection.close() 
    quit() 

temp = '50'の3番目の値でクラッシュします。

私は全く困惑していて、何が間違っているのか分かりません。

+0

エラーメッセージに応じて文字列 '? '(' 50 '、)が実際にXML属性で定義された内容ではないと言っていますか?その場合は、XMLパーサには問題がありますが、sqlalchemyやsqliteでは問題ありません。 – jogojapan

+0

私は言ったように、すべてのtemp.text値がメッセージボックスに正しく表示されるため(最後の行を削除した場合)、xmlパーサーに問題はありません。さらに、xmlファイルと同じ構文解析メソッドをプログラムに使用しています。問題はありません。私はxmlからsqliteに変更したいだけです。 – linuxoid

+0

あなたのエラーは 't_id = select([tb_temperatures.c.id]、tb_temperatures.c.temperature == temp.text)'の問題ですが、最後のinsert文とその動作を削除していますか?あなたがコンソールに持っている全体のトレースバックを提供してください。 – Nilesh

答えて

1

私の方法であなたのコードを試しました。 をテストするためにQT4とsqlitefktg4saを持っていないので、コードをSQLAlchemy構文に限定して変換します。私はまた、私はダミーの値を挿入するので、解析するあなたのXMLを持っていない。

コードは私は、Python 2.7、SQLAlchemyの0.7、Fedoraでこれをテスト

import sys 
from sqlalchemy import create_engine 
from sqlalchemy import Table, Column, Integer, String, Float, MetaData, ForeignKey 
from sqlalchemy.sql import select, and_ 

db_file = "/my/home/db.sqlite" 
db = create_engine('sqlite:///' + db_file, echo=True) 
connection = db.connect() 

metadata = MetaData() 

tb_materials = Table('materials', metadata, 
      Column('id', Integer, primary_key=True), 
      Column('material', String) 
      ) 

tb_temperatures = Table('temperatures', metadata, 
      Column('id', Integer, primary_key=True), 
      Column('temperature', String) 
      ) 

tb_mat_data = Table('mat_data', metadata, 
      Column('id', Integer, primary_key=True), 
      Column('mat_id', None, ForeignKey('materials.id', onupdate="CASCADE", ondelete="CASCADE")), 
      Column('temp_id', None, ForeignKey('temperatures.id', onupdate="CASCADE", ondelete="CASCADE")), 
      Column('density', String), 
      Column('elasticity', String), 
      Column('stress', String) 
      ) 


metadata.create_all(db) 


matlist = ['mat1', 'mat2', 'mat3'] 
templist = ['temp1', 'temp2', 'temp3'] 

data = tb_materials.insert().values(material = "CS") 
connection.execute(data) 

for m in matlist: 
    data = tb_materials.insert().values(material = m) 
    connection.execute(data) 

for t in templist: 
    data = tb_temperatures.insert().values(temperature = t) 
    connection.execute(data) 


m_id = select([tb_materials.c.id], tb_materials.c.material == 'mat3') 
row = connection.execute(m_id) 
data = row.fetchone() 
m_id_key = data[0] 

t_id = select([tb_temperatures.c.id], tb_temperatures.c.temperature == 'temp1') 
row = connection.execute(t_id) 
data = row.fetchone() 
t_id_key = data[0] 

z = tb_mat_data.insert().values(mat_id = m_id_key, temp_id = t_id_key, density = 'density', elasticity = 'electricity', stress = 'stress') 
connection.execute(z) 

connection.close() 

あります。これは私のために働いています。問題が発生しているxmlデータを提供していれば、あなたの場所で試してみてください。

これはあなたの問題を理解するのに役立ちます。

+0

XMLとは何の関係もなく、xmlをtemps = ['25'、 '38'、 '50'、 '100']に置き換えました。 WTH!それは気違いです。または私は何ですか? – linuxoid

+0

はい、あなたのコードが動作します。だから、他のモジュールではすべて私のものです。この特定のもので何か変だ。 – linuxoid

関連する問題