Maison > interface Web > js tutoriel > le corps du texte

Comment importer des données par lots avec ajax

php中世界最好的语言
Libérer: 2018-04-04 17:26:52
original
2233 Les gens l'ont consulté

Cette fois, je vais vous montrer comment importer des données par lots avec ajax Quelles sont les précautions pour l'importation de données par lots ajax Voici un cas pratique, jetons un oeil.

L'exemple de cet article partage avec vous la méthode d'implémentation d'utilisation d'ajax pour implémenter la fonction d'importation de données par lots dans la page Web pour votre référence. Le contenu spécifique est le suivant

url.py. code :

url(r'^workimport/$', 'keywork.views.import_keywork', name='import_keywork')
Copier après la connexion

view.py code :

from keywork.models import DevData
from django.http import JsonResponse #django ajax部分
def import_keywork(request):
 file_sjdr = request.POST['file_keywork']
 f = open(file_sjdr)
 WorkList = []
 next(f) #将文件标记移到下一行
 x = y = 0
 for line in f:
  parts = line.replace('"','') #将字典中的"替换空
  parts = parts.split(',') #按;对字符串进行切片
  if DevData.objects.filter(serv_id = parts[0],user_flag=parts[15]).exists():
   x = x + 1
  else:
   y = y + 1
   WorkList.append(DevData(serv_id=parts[0], serv_state_name=parts[1], acc_nbr=parts[2], user_name=parts[3], acct_code=parts[4], product_id=parts[5],
       mkt_chnl_name=parts[6], mkt_chnl_id=parts[7],mkt_region_name=parts[8], mkt_region_id=parts[9],mkt_grid_name=parts[10],
       sale_man=parts[11],sale_outlets_cd1_name=parts[12], completed_time=parts[13],remove_data=parts[14], user_flag=parts[15],
       pro_flag=parts[16], service_offer_id=parts[17],service_offer_name=parts[18], finish_time=parts[19],staff_name=parts[20],
       staff_code=parts[21],org_name=parts[22],prod_offer_name=parts[23],day_id=parts[24],
       ))
 f.close() 
 DevData.objects.bulk_create(WorkList)
 num = {'success':str(y) ,'fail':str(x) , 'sum':str(x+y)}
 return JsonResponse(num)
Copier après la connexion

Cette partie du code fait référence à l'article précédent (Importation par lots Django de données non dupliquées )

Code dans le modèle :

$('#btn_sjdr').click(function(){
   $.post("{% url 'import_keywork' %}",
     {
       csrfmiddlewaretoken:"{{ csrf_token }}",
      file_keywork:$("#file_keywork").val(),
     },
     function(data,status) { 
      $("#test1").html(status+"重复数据"+data['fail']+"条,成功导入数据"+data['success']+"条");   
     }           
   )
  });  
<form>
     {% csrf_token %}
     <label><i class="icon-file"></i> 请选择需要被导入的文件</label>
     <input id="file_keywork" type="file"/>
     <input type="button" id="btn_sjdr" value="导入" class="btn btn-primary btn-sm"/>
    </form>
    <p id="test1"></p>
   </p>
Copier après la connexion

Le formulaire utilise post+ajax Notez que l'utilisation de la méthode post pour soumettre un formulaire dans Django doit remplir deux conditions :

Ajoutez {% csrf_token %} au formulaire, et ajoutez le code

jquery Ajoutez simplement csrfmiddlewaretoken : "{{ csrf_token }}" et c'est tout

Je crois que vous maîtrisez la méthode ! après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de PHP !

Lecture recommandée :

Explication détaillée de l'utilisation de l'objet XMLHttpRequest d'AJAX

Comment ajax réalise-t-il une longue connexion entre le serveur et le navigateur

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal