django csv自动导入

时间:2018-11-24 08:46:53

标签: python mysql django csv django-models

我是来自意大利的Marcello,我是python和jango的新手。我问一个问题,以获取有关我在Django项目的信息。

我创建了一个有两个表的项目,我的问题是如何自动从csv获取数据,我将创建一个存储csv.txt的ftp服务器并更新表(例如每天)。

现在,我将手动更新Django导入/导出。我希望django读取csv文件并更新db,然后删除。

非常感谢您的支持!

我的模型。py:

from django.db import models
from django.urls import reverse



class AnagraficaCliente(models.Model):
    codice_cliente = models.CharField(max_length=20, primary_key=True, 
                                      null=False, unique=True)
    ragione_sociale = models.CharField(max_length=40)
    ragione_sociale_dest = models.CharField(max_length=40)
    nome = models.CharField(max_length=20, blank=True)
    cognome = models.CharField(max_length=20, blank=True)
    ragione_sociale = models.CharField(max_length=20)
    indirizzo = models.TextField(blank=True)
    cap = models.CharField(max_length=5, blank=True)
    piva = models.CharField(max_length=11, blank=True)
    vatnumber = models.CharField(max_length=13, blank=True)
    ragione_sociale_dest = models.CharField(max_length=40)
    indirizzo_dest = models.TextField(null=True)

    def __str__(self):
        #return self.ragione_sociale + " " + self.codice_cliente
        return self.ragione_sociale_dest + " " + self.indirizzo_dest 

    class Meta:
        verbose_name = "AnagraficaCliente"
        verbose_name_plural = "AnagraficaClienti"




class Tracking(models.Model):
    track = models.CharField(max_length=10, null=False, unique=True, 
                             primary_key=True)
    passaggio1 = models.CharField(max_length=50, blank=True)
    passaggio2 = models.CharField(max_length=50, blank=True)
    passaggio3 = models.CharField(max_length=50, blank=True)
    passaggio4 = models.CharField(max_length=50, blank=True)
    passaggio5 = models.CharField(max_length=50, blank=True)
    consegna = (
        ('C', 'Consegnato'),
        ('N', 'Non consegnato'),
    )
    consegnato = models.CharField(max_length=1, choices=consegna)

    #consegnato = models.BooleanField(blank=True)
    #esito = models.CharField(max_length=10, blank=True)
    flag = models.CharField(max_length=2, blank=True)
    AnagraficaCliente = models.ForeignKey(AnagraficaCliente, 
    on_delete=models.CASCADE, related_name='trackings')

    def __str__(self):
        return self.track

    class Meta:
        verbose_name = "Tracking"
        verbose_name_plural = "Trackings"

我制作了一个脚本,该脚本从trackingtest.csv读取并存储在result_str_csv_anag_index_8_list中,然后从anagraficatest.csv读取并插入mysql中,此后,我从表tracking_anagraficacliente获取查询( 如果外键是正确的,则我将最后一个字段数据存储在result_str_query_anag_index_8_list中,然后在result_str_query_anag_index_8_list中比较result_str_csv_anag_index_8_list。

所有这些都在Linux中使用cron进行,但是我想在django(后端)中实现警报(例如,如果插入正常,则按钮为红色或绿色)。

我希望是初学者;)

谢谢。

#!/usr/bin/python3

import csv
import MySQLdb, time

sql_anag= """
        INSERT INTO tracking_anagraficacliente 
        (codice_cliente,nome,cognome,ragione_sociale,indirizzo,cap,piva,vatnumber,ragione_sociale_dest,indirizzo_dest)
        VALUES 
        (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s) 
        ON DUPLICATE KEY UPDATE 
                                                    -- no primary key  aggiornata

        nome   = VALUES(nome),
        cognome   = VALUES(cognome),
        ragione_sociale   = VALUES(ragione_sociale),
        indirizzo   = VALUES(indirizzo),
        cap   = VALUES(cap),
        piva   = VALUES(piva),
        vatnumber   = VALUES(vatnumber),
        ragione_sociale_dest   = VALUES(ragione_sociale_dest),
        indirizzo_dest   = VALUES(indirizzo_dest);
        """
    sql_track= """
        INSERT INTO tracking_tracking 

        VALUES 
        (%s, %s, %s, %s, %s, %s, %s, %s, %s) 
        ON DUPLICATE KEY UPDATE 
                                                    -- no primary key  aggiornata

        passaggio1   = VALUES(passaggio1),
        passaggio2   = VALUES(passaggio2),
        passaggio3   = VALUES(passaggio3),
        passaggio4   = VALUES(passaggio4),
        passaggio5   = VALUES(passaggio5),
        consegnato   = VALUES(consegnato),
        flag   = VALUES(flag),
        AnagraficaCliente_id  = VALUES(AnagraficaCliente_id);
        """
query_id_anag = """ select codice_cliente from tracking_anagraficacliente; """
#query_id_track = """ select AnagraficaCliente_id from tracking_tracking; """


db = MySQLdb.connect(
        host="localhost",    # your host
        user="xxxxxxx",         # your username
        passwd="xxxxxx",  # your password
        db="lm_cms")        # name of the data base

cur = db.cursor()

with open('trackingtest.csv') as csvfile: #
readCSVQuery = csv.reader(csvfile, delimiter=',') 
next (readCSVQuery) 
list_csv_tracking = [] 
for i in readCSVQuery: 
    trackAnagraficaId = i[8]
    list_csv_tracking.append(trackAnagraficaId) 
result_str_csv_track_index_8 = str(list_csv_tracking).replace(",", 
"").replace("[", "").replace("]", "") 
result_str_csv_anag_index_8_list = result_str_csv_track_index_8.split(' ') 
print ("Risultato CSV Tracking Foreign 
Key",result_str_csv_anag_index_8_list)

def insert_anagrafica():
    with open('anagraficatest.csv') as csvfile: #read CSV anagraficatest
        readCSV = csv.reader(csvfile, delimiter=',')
        next (readCSV) # Jump first line
        for row_anag in readCSV:
            try:
                cur.execute (sql_anag, (row_anag)) #Insert data on mysql
                db.commit() # Commit your changes in the database
                print(row_anag)
            except (MySQLdb.Error, MySQLdb.Warning) as e: #Exception
                print(e)
                db.rollback() # Rollback in case there is any error
                db.close()

def query_anag():
    cur.execute(query_id_anag) #Execute query to get codice_cliente from tracking_anagraficacliente
    results_query_id_anag = cur.fetchall() # Get all data from query and assign to results_query_id_anag
    result_query_anag = str(results_query_id_anag).replace("(", "").replace(")", "").replace(",", "")# Delete ( ) , from results_query_id_anag and convert to string
    result_str_query_anag_index_8_list = result_query_anag.split(' ') # Convert in string from result_query_anag to result_str_query_anag_index_8_list
    print ("Risultato Query anagrafica Codice cliente  ",result_str_query_anag_index_8_list)
    return result_str_query_anag_index_8_list #return value

def insert_tracking():
    with open('trackingtest.csv') as csvfile: #Read Csv
        readCSV = csv.reader(csvfile, delimiter=',') #Read csv file
        next (readCSV) #Jump first line
        #print (results_query_id_anag)
        #compare if AnagraficaClienteID in trackingtest.csv is  present in mysql tracking_aanagraficacliente Codice Cliente
        #,if present make the insert  sql_track else no
        for i in result_str_csv_anag_index_8_list: #compare element lists in result_str_csv_anag_index_8_list is present in result_str_query_anag_index_8_list
            if i in result_str_query_anag_index_8_list:
                for row_track in readCSV: # Read all the line in trackingtest.csv
                    try:
                        #print(row_track[0])
                        #print(row_track)

                        cur.execute (sql_track, (row_track)) #Insert data trackingtest.csv in tracking_tracking
                        db.commit() # Commit your changes in the database
                        print ("Insert effettuata con successo ", row_track)
                    except (MySQLdb.Error, MySQLdb.Warning) as e:
                        print (e, "Riga non inserita: ",row_track)
                        #db.close() # disconnect from server
            else:
                print ("Attenzione, una o più righe non sono state inserite")


insert_anagrafica()
time.sleep(2)
(result_str_query_anag_index_8_list) = query_anag() #value passed from def query_anag() to insert_tracking
time.sleep(2)
insert_tracking()

0 个答案:

没有答案