iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >django 批量导入数据
  • 695
分享到

django 批量导入数据

2024-04-02 19:04:59 695人浏览 安东尼
摘要

一、需求我在数据库中建了一张表,用来保存ucloud云上的project id 和project namemodels.py代码如下#coding:utf-8 from Django.db&nbs

一、需求

我在数据库中建了一张表,用来保存ucloud云上的project id 和project name

models.py代码如下

#coding:utf-8
from Django.db import models

class Project(models.Model):
    name = models.CharField(u'项目名称',max_length=32,blank=True)
    id = models.CharField(u'项目ID',max_length=32,unique=True,primary_key=True,blank=True)
    create_date = models.DateTimeField(u'创建时间', auto_now_add=True)
    update_date = models.DateTimeField(u'更新时间', auto_now=True)
    def __unicode__(self):
        return self.name


admin.py代码如下

from djanGo.contrib import admin
from ucloud.models import *

class ProjectAdmin(admin.ModelAdmin):
    list_display = ['name','id']
admin.site.reGISter(Project,ProjectAdmin)

django 批量导入数据

二、批量导入脚本

现在,我准备了一个脚本,通过Ucloudapi获取到了线上所有的项目的项目ID和项目名称

#!/usr/bin/env python
#-*-coding:utf8-*-
from Ucloud_API.config import *
from Ucloud_API.sdk import UcloudApiClient
from models import *

def get_project_info():
    ApiClient = UcloudApiClient(base_url, public_key, private_key)
    Parameters = {
        "Action": "GetProjectList"
    }
    response = ApiClient.get("/", Parameters)
    ids = [
        {'ProjectId': _['ProjectId'], 'ProjectName': _['ProjectName']}
        for _ in response['ProjectSet']
        ]
    return ids
##脚本执行结果如下
[{'ProjectId': u'org-81', 'ProjectName': u'\u4e0a\u6d77\u522b\u6837\u7ea2\u4fe1\u606f\u6280\u672f\u6709\u9650\u516c\u53f8'}, {'ProjectId': u'org-ja1wvv', 'ProjectName': u'\u5907\u6848\u4e13\u7528'}, {'ProjectId': u'org-wrg10n', 'ProjectName': u'gitlab'}, {'ProjectId': u'org-pni2a2', 'ProjectName': u'PublicTest'}, {'ProjectId': u'org-kbxrx4', 'ProjectName': u'SPMS'}, {'ProjectId': u'org-aws3Dj', 'ProjectName': u'\u5b89\u5168\u6d4b\u8bd5'}, {'ProjectId': u'org-vzfixt', 'ProjectName': u'OTA'}, {'ProjectId': u'org-et55qg', 'ProjectName': u'99\u6570\u636e\u540c\u6b65\u4e2d\u8f6c\uff0c\u672c\u9879\u76ee\u4e0e99\u5185\u7f51\u6253\u901a\uff0c\u4e0d\u5141\u8bb8\u6dfb\u52a0\u4efb\u4f55\u673a\u5668'}, {'ProjectId': u'org-ghan2t', 'ProjectName': u'Ops'}, {'ProjectId': u'org-qf4d2n', 'ProjectName': u'iPms'}]

ProjectId对象表中的id字段,ProjectName对应表中的name字段。


下面是批量导入数据的代码:

#!/usr/bin/env Python
#-*-coding:utf8-*-
from Ucloud_API.config import *
from Ucloud_API.sdk import UcloudApiClient
from models import *

##通过API获取数据
def get_project_info():
    ApiClient = UcloudApiClient(base_url, public_key, private_key)
    Parameters = {
        "Action": "GetProjectList"
    }
    response = ApiClient.get("/", Parameters)
    ids = [
        {'ProjectId': _['ProjectId'], 'ProjectName': _['ProjectName']}
        for _ in response['ProjectSet']
        ]
    return ids

##批量导入数据
def update_project_info():
    info = get_project_info()
    pids = []
    for _ in info:
        projectid = _['ProjectId']
        pids.append(projectid)
        project = None
        try:
            project = Project.objects.get(pk=projectid)
        except Project.DoesNotExist:
            project = Project(pk=projectid)
        project.name = _['ProjectName']
        project.save()
    # 删除本地有但是ucloud上没有的项目
    projectids = [_['pk'] for _ in Project.objects.all().values('pk')]
    diff_ids = list(set(projectids).difference(set(pids)))
    Project.objects.filter(pk__in=diff_ids).delete()

这里导入数据的思路如下:

try:
    project = Project.objects.get(pk=projectid)
except Project.DoesNotExist:
    project = Project(pk=projectid)

先通过get方法获取对象,如果对象bu'存在,则用下面的方法创建该对象

project = Project(pk=projectid)

如果对象存在,通过下面的方法更新ProjectName

project.name = _['ProjectName']
project.save()


另外还有一个需要注意的地方是,数据库中的数据要更新。

例如:线上之前有一个项目aaa,但是后来被删除了,那么则需要从数据库中删除该对象。

使用以下方法;

projectids = [_['pk'] for _ in Project.objects.all().values('pk')]
diff_ids = list(set(projectids).difference(set(pids)))
Project.objects.filter(pk__in=diff_ids).delete()

将数据库中的对象列表转换成集合,将线上获取到的对象列表也转换成集合,然后通过

set1.difference(set2)

的方法来获取在set1中存在,但在set2中不存在的对象,然后用下面的方法删除

Project.objects.filter(pk__in=diff_ids).delete()


批量导入数据还可以使用下面的方法执行

def update_project_info():
    info = get_project_info()
    pids = [_['ProjectId'] for _ in info]
    for i in info:
        Project.objects.get_or_create(id=i['ProjectId'],name=i['ProjectName'])
    projectids = [_['pk'] for _ in Project.objects.all().values('pk')]
    #获取数据库中存在,但线上不存在的projectid
    diff_ids = list(set(projectids).difference(set(pids)))
    #删除数据库中多余的数据
    Project.objects.filter(pk__in=diff_ids).delete()
Project.objects.get_or_create(id=i['ProjectId'],name=i['ProjectName'])

 get_or_create() 有就获取过来,没有就创建,用它可以避免重复,但是速度可以会慢些,因为要先尝试获取,看看有没有


三、如何执行脚本

我们可以将导入数据的方法通过问url的方式,来执行


#coding:utf-8
from django.shortcuts import render
from django.Http import HttpResponse,JSONResponse
from sdkucloud import *
# Create your views here.
def index(request):
    return HttpResponse('index')
def pull_project(request):
    update_project_info()
    return HttpResponse('OK!')

编辑$APPName/urls.py

from django.conf.urls import include, url
from django.contrib import admin
from ucloud.views import *
urlpatterns = [
    url(r'^$',  index),
    url(r'^pull_project/$', pull_project)
]








您可能感兴趣的文档:

--结束END--

本文标题: django 批量导入数据

本文链接: https://www.lsjlt.com/news/52803.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • django 批量导入数据
    一、需求我在数据库中建了一张表,用来保存ucloud云上的project id 和project namemodels.py代码如下#coding:utf-8 from django.db&nbs...
    99+
    2024-04-02
  • java批量导入Excel数据
    后台导入代码 import cn.afterturn.easypoi.excel.entity.ImportParams;import cn.afterturn.easypoi.excel.entity.result.ExcelImport...
    99+
    2023-09-01
    java excel vue.js
  • Redis批量导入文本数据
    # 查看导入的文本文件,里面是具体的Redis命令 # cat 20180208.txt hdel user.user.base 317986 ...
    99+
    2024-04-02
  • Redis如何批量导入数据
    Redis批量导入数据的示例:准备一个redis protocol的文件,通过java程序来输出的,代码如下:<<RedisBatchTest>>public class RedisBatchTe...
    99+
    2024-04-02
  • oracle怎么批量导入大量数据
    Oracle数据库可以通过多种方式批量导入大量数据,以下是一些常用的方法: SQLLoader工具:SQLLoader是Orac...
    99+
    2024-04-16
    oracle
  • PostgreSQL中怎么批量导入数据
    这篇文章将为大家详细讲解有关PostgreSQL中怎么批量导入数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。概述考虑PostgreSQL数据库批量导入数...
    99+
    2024-04-02
  • MySQL中怎么批量导入数据
    本篇文章为大家展示了MySQL中怎么批量导入数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。MySQL批量导入数据操作应该如何实现下面就将以MySQL数据库为例,...
    99+
    2024-04-02
  • SQLSERVER怎么大批量导入数据
    在SQL Server中,可以使用以下方法进行大批量数据导入:1. 使用BULK INSERT语句:BULK INSERT语句允许从...
    99+
    2023-08-18
    SQLSERVER
  • 如何将批量数据导入mysql数据库
    这篇文章将为大家详细讲解有关如何将批量数据导入mysql数据库,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。如何将批量数据导入mysql数据库1.创建一个e...
    99+
    2024-04-02
  • Django框架如何利用ajax实现批量导入数据功能
    这篇文章给大家分享的是有关Django框架如何利用ajax实现批量导入数据功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下url.py代码:url(r'^workimport/$',...
    99+
    2023-06-08
  • SQL Server怎么批量导入和导出数据
    在SQL Server中,可以使用bcp命令行实用程序批量导入和导出数据。以下是一些示例:1. 批量导入数据:使用bcp命令行实用程...
    99+
    2023-10-10
    SQL Server
  • MySQL怎么批量导入数据优化
    这篇文章将为大家详细讲解有关MySQL怎么批量导入数据优化,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 --MyISAM表my...
    99+
    2024-04-02
  • MySQL批量导入Excel数据【超详细】
    查看此文章前强烈建议先看这篇文章:Java江湖路 | 专栏目录 今天遇到一个需求,批量更新数据库中全国各地的物流价格,产品经理很贴心的为我做好了数据表格,说是上一个技术也是这么做的,好,压力给到我这边。话不多说,直接上步骤。 1...
    99+
    2023-08-18
    mysql Excel
  • 怎么在mysql中批量导入数据
    在mysql中批量导入数据的方法有:1.使用循环语句导入;2.使用MYSQL LOCAL_INFILE语句导入;3.通过拼接sql导入;4.使用存储过程导入;在mysql中批量导入数据的方法以下几种使用循环语句导入使用循环语句导入数据时,适...
    99+
    2024-04-02
  • 服务器怎么批量导入与导出数据
    这篇文章主要讲解了“服务器怎么批量导入与导出数据”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“服务器怎么批量导入与导出数据”吧!在使用IIS7远程桌面时,若有多个服务器需要添加,而逐一进行选...
    99+
    2023-06-05
  • SQL Server Bulk Insert如何批量数据导入
    小编给大家分享一下SQL Server Bulk Insert如何批量数据导入,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2024-04-02
  • mysql如何高效导入大批量数据
    要高效导入大批量数据到MySQL中,可以使用以下方法: 使用LOAD DATA INFILE语句:这是MySQL提供的一个高效的...
    99+
    2024-05-13
    mysql
  • Excel数据如批量导入navicat的方法
    这篇文章主要介绍了Excel数据如批量导入navicat的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。打开电脑上的Navicat,点击左上...
    99+
    2024-04-02
  • phpmyadmin如何批量导入excel数据到mysql
    这篇文章主要介绍phpmyadmin如何批量导入excel数据到mysql,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先我们得到了一个excel表,里面有很多需要我们导入的数据删...
    99+
    2024-04-02
  • Python实现批量导入1000条xlsx数据
    遇到的问题: 用户批量导入数据1000条,导入不成功的问题,提示查询不到商品资料。这个场景需要依靠批量的数据,每次测试的时候需要手动生成批量的数据,然后再导入操作,费时费劲。所以写了...
    99+
    2023-02-16
    Python 批量导入xlsx Python 批量导入
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作