2016-12-16 55 views
1

enter image description herepandas.read_csv:OperationalError:表沒有指定列1

我想一個CSV上傳到sqllite表上使用Windows:

的sqllite表和CSV具有相同的字段名並開始與:

CREATE TABLE test2 (
id INTEGER NOT NULL, 
"case" TEXT, 
...... 
PRIMARY KEY (id), 
UNIQUE ("case") 
) 

我有下面的類:

class Sqllite_utilities(object): 

    def __init__(self, db_path, table_name): 
     self.db_path = db_path 
     self.table_name = table_name 

    def upload_csv_to_table(self, path_to_csvfile): 
     conn = sqlite3.connect(self.db_path) 
     df = pandas.read_csv(path_to_csvfile) 
     df.to_sql(self.table_name, conn, if_exists='append', index_label='id') 

在命令行上:

s = Sqllite_utilities(settings.SETTINGS_PATH+"\\data.db",'test2') 

In[3]: s.upload_csv_to_table('C:\Users\ne\Desktop\jtest.csv') 
C:\lib\site-packages\pandas\core\generic.py:1201: UserWarning: The spaces in these column names will not be changed. In pandas versions < 0.14, spaces were converted to underscores. 
    chunksize=chunksize, dtype=dtype) 
Traceback (most recent call last): 
    File "C:\lib\site-packages\IPython\core\interactiveshell.py", line 2885, in run_code 
    exec(code_obj, self.user_global_ns, self.user_ns) 
    File "<ipython-input-3-b530f5199977>", line 1, in <module> 
    s.upload_csv_to_table('C:\Users\dnir\Desktop\jtest.csv') 
    File "F:\ENVS\r2\j1\utilities.py", line 41, in upload_csv_to_table 
    df.to_sql(self.table_name, conn, if_exists='append', index_label='id') 
    File "C:\lib\site-packages\pandas\core\generic.py", line 1201, in to_sql 
    chunksize=chunksize, dtype=dtype) 
    File "C:\lib\site-packages\pandas\io\sql.py", line 470, in to_sql 
    chunksize=chunksize, dtype=dtype) 
    File "C:\lib\site-packages\pandas\io\sql.py", line 1503, in to_sql 
    table.insert(chunksize) 
    File "C:\lib\site-packages\pandas\io\sql.py", line 664, in insert 
    self._execute_insert(conn, keys, chunk_iter) 
    File "C:\lib\site-packages\pandas\io\sql.py", line 1291, in _execute_insert 
    conn.executemany(self.insert_statement(), data_list) 
OperationalError: table test2 has no column named 1 

我在做什麼錯?

編輯:我覺得你得到了它,我得到一個新的錯誤,我會考慮這樣做seperately:

df.to_sql(self.table_name, conn, if_exists='append', index_label='id') 
File "C:\lib\site-packages\pandas\core\generic.py", line 1201, in to_sql 
    chunksize=chunksize, dtype=dtype) 
File "C:\lib\site-packages\pandas\io\sql.py", line 470, in to_sql 
    chunksize=chunksize, dtype=dtype) 
File "C:\lib\site-packages\pandas\io\sql.py", line 1503, in to_sql 
    table.insert(chunksize) 
File "C:\lib\site-packages\pandas\io\sql.py", line 642, in insert 
    keys, data_list = self.insert_data() 
File "C:\lib\site-packages\pandas\io\sql.py", line 609, in insert_data 
    "duplicate name in index/columns: {0}".format(err)) 
ValueError: duplicate name in index/columns: cannot insert id, already exists 
+0

並表已經存在,而沒有列名? – jeremycg

+0

是表存在,並沒有名爲'1'的列' – user61629

+0

所以然後你的熊貓dataframe列需要匹配db列名 – jeremycg

回答

2

問題就出在索引列,大熊貓具有的索引數據幀作爲列'索引'。如果你不想在沒有它的情況下插入記錄,試試這個;

df.to_sql(...,指數= FALSE)