2017-07-29 3 views
0

Ich bin ein Neuling. Ich habe ein wenig gesucht, aber ich finde keine Antwort auf dieses Problem. Ich versuche, einen dynamischen Dateneintrag mit Sqlite3 und Python 3 auszuführen, aber ich erhalte einen Fehler.
Es sollte eine test1.db-Datei erstellen, aber es ist leer.Fehler in Sqlite3: OperationalError: keine solche Tabelle

Fehler:

Traceback (most recent call last): 
File "/home/dominic/Documents/Database_Tutorial.py", line 35, in <module> 
dynamic_data_entry() 
File "/home/dominic/Documents/Database_Tutorial.py", line 29, in dynamic_data_entry 
(unix, date, keyword, value)) 
sqlite3.OperationalError: no such table: stuffToPlot 

Database_Tutorial.py

import sqlite3 
import time 
import datetime 
import random 

conn = sqlite3.connect('test1.db') 
c = conn.cursor() 


def create_table(): 
    c.execute("CREATE TABLE IF NOT EXISTS stuffToPlot(unix REAL, datestamp TEXT, keyword TEXT, value REAL)") 


def data_entry(): 
    c.execute("INSERT INTO stuffToPlot VALUES(1452549219,'2016-01-11 13:53:39','Python',6)") 

    conn.commit() 
    c.close() 
    conn.close() 


def dynamic_data_entry(): 
    unix = int(time.time()) 
    date = str(datetime.datetime.fromtimestamp(unix).strftime('%Y-%m-%d %H:%M:%S')) 
    keyword = 'Python' 
    value = random.randrange(0, 10) 

    c.execute("INSERT INTO stuffToPlot (unix, datestamp, keyword, value) VALUES (?, ?, ?, ?)", 
      (unix, date, keyword, value)) 

    conn.commit() 


for i in range(10): 
    dynamic_data_entry() 
    time.sleep(1) 

c.close 
conn.close() 

Bitte helfen.

Antwort

0

Sie müssen create_table() vor der Dateneingabe aufrufen.

Verwandte Themen