karideo/back/transfer_bdd/v0.0...v1.0/transfert_video.py

147 lines
3.2 KiB
Python
Executable File

#!/usr/bin/python3
# -*- coding: utf-8 -*-
##
## @author Edouard DUPIN
##
## @copyright 2012, Edouard DUPIN, all right reserved
##
## @license MPL v2.0 (see license file)
##
#pip install paho-mqtt --user
from realog import debug
import json
import os
import random
import copy
from dateutil import parser
import datetime
def file_read_data(path):
if not os.path.isfile(path):
return ""
file = open(path, "r")
data_file = file.read()
file.close()
return data_file
debug.info("Load old BDD: ")
data = file_read_data('bdd_video.json')
my_old_bdd = json.loads(data)
debug.info("open new BDD: ")
import sqlite3
conn = sqlite3.connect('bdd_video.db3')
debug.info("create the table:")
c = conn.cursor()
# Create table
c.execute('''
CREATE TABLE data (
id INTEGER PRIMARY KEY,
deleted INTEGER,
create_date INTEGER NOT NULL,
modify_date INTEGER NOT NULL,
name TEXT NOT NULL,
description TEXT,
covers TEXT,
data_id INTEGER,
type_id INTEGER,
univers_id INTEGER,
group_id INTEGER,
saison_id INTEGER,
date INTEGER,
episode INTEGER,
time INTEGER)
''')
def list_to_string(data):
out = "";
for elem in data:
if out != "":
out += "/"
out +=str(elem)
return out
#sqlite3 bdd_group.db3 "SELECT * from data"
debug.info("insert elements: ")
iii = 0;
for elem in my_old_bdd:
iii+=1;
debug.info("[" + str(iii) + "/" + str(len(my_old_bdd)) + "] send new element")
id = elem["id"]
time = elem["create_date"].replace("Z","").replace("H"," ");
tmp_time = parser.parse(time)
debug.info(" => " + str(tmp_time) + " from " + elem["create_date"])
new_time = int(tmp_time.timestamp())
modify_time = int(datetime.datetime.utcnow().timestamp());
name = elem["name"]
if "description" not in elem.keys():
description = None
else:
description = elem["description"]
if "covers" not in elem.keys():
covers = []
else:
covers = elem["covers"]
if covers == None:
covers = [];
if "data_id" not in elem.keys():
data_id = None
else:
data_id = elem["data_id"]
if "type_id" not in elem.keys():
type_id = None
else:
type_id = elem["type_id"]
if "univers_id" not in elem.keys():
univers_id = None
else:
univers_id = elem["univers_id"]
if "group_id" not in elem.keys():
group_id = None
else:
group_id = elem["group_id"]
if "saison_id" not in elem.keys():
saison_id = None
else:
saison_id = elem["saison_id"]
if "date" not in elem.keys():
date = None
else:
date = elem["date"]
if "episode" not in elem.keys():
episode = None
else:
episode = elem["episode"]
if "time" not in elem.keys():
time = None
else:
time = elem["time"]
request_insert = (id, new_time, modify_time, name, description, list_to_string(covers), data_id, type_id, univers_id, group_id, saison_id, date, episode, time)
c.execute('INSERT INTO data VALUES (?,0,?,?,?,?,?,?,?,?,?,?,?,?,?)', request_insert)
# Save (commit) the changes
conn.commit()
def dict_factory(cursor, row):
d = {}
for idx, col in enumerate(cursor.description):
d[col[0]] = row[idx]
return d
conn.row_factory = dict_factory
c = conn.cursor()
c.execute('SELECT * FROM data WHERE deleted=false')
results = c.fetchall()
print(results)
# We can also close the connection if we are done with it.
# Just be sure any changes have been committed or they will be lost.
conn.close()