Django 进度条前端实时更新后端处理进度 – python后端实现进度条

今天在做自动化交易程序 的时候,需要有个界面要展示进度条.因为工程是用 django 框架开发.很多知识都需要自己去学习.

自己找了很多的方法 去实现 django 的进度条功能. 网上搜搜了很多, 对于小白来说都没有很好的教程实现 Python 后端实现进度条的功能. 

作为开源程序的倡导者,我要贡献给刚入门的朋友. 大牛请飘过......

 

 

 

这是程序效果, 下边的是打印的一些日志. 这个可以取消. 关键是 django Python 后端进度条的功能已经实现. 前端是基于基于bootstrap的进度条. 这个不动的自行百度.不过我在写程序的时候仅知道 bootstrap 是一个前端框架而已.不需要了解太多.除非你是前端攻城狮 项目用的很多.

1.Python 后端进度条交互逻辑:


点击页面的“展示进度条测试数据”button,向后台发送数据处理请求;
后台处理数据;process_data

前端根据后台的处理进度实时更新进度条。

此程序 的负载主要集中在前端,所以对后端的负载很小. 

 

2. Python 后端进度条 前端 代码:

 

2.1 UI html 

Html页面用boostrap的进度条, 进度条由2个div嵌套而成,修改内层div的width可以更新进度

<body>
    <!--1. 按钮-->
    <div class="container">

        <button class="btn btn-default" type="button">展示进度条测试数据</button>


	    <!--2. 进度条-->
	    <div  class="progress-div">
	        <div class="progress">
	            <div class="progress-bar progress-bar-striped active" role="progressbar" aria-valuenow="2" aria-valuemin="0" aria-valuemax="100" style="min-width: 2em; width: 2%;">
	                2%
	            </div>
	        </div>
	    </div>

    </br>

         <div class="progress-text progress-bar-striped active"  role="progressbar" aria-valuenow="2" aria-valuemin="0" aria-valuemax="100" style="min-width: 2em; width: 2%;">

	            </div>



    </div>
</body>

 

2.2  javascript 代码实现 (主要功能)

 

这里边可以看到在更新前端界面的时候设置 10 秒钟去更新后台的数据.这个地方因为测试的数据特别快,在正常的业务中可以设置 1 秒.

在 点击click方法中

1.设置一个setInterval函数,用于持续请求后台进度,不断更新进度条;
2. 向后台发送数据处理请求,当该请求成功返回后结束setInterval函数,并更改进度条样式。
由于setInterval和getJSON的回调函数都是异步执行,这里就相当于做了个登记,将任务加入队列。
 

<script>

 $(function () {
        $('.btn').on('click', function () {
                console.log("come in ")
                var log = ""
                var sitv = setInterval(function(){

                    var prog_url = '/show_progress'              // prog_url指请求进度的url,后面会在django中设置
                    $.getJSON(prog_url, function(num_progress){


{#                         console.log("come in num_progress="+num_progress)#}
                        log = log + num_progress+ "-"
                        $('.progress-div').css('visibility', 'visible');
                        $('.progress-bar').css('width', num_progress + '%');
                        $('.progress-bar').text(num_progress + '%');
                        $('.progress-text').text( '显示日志'+log );
                        $('.progress-text').css('width', '100%');

            {#            $('#prog_in').width(res + '%');     // 改变进度条进度,注意这里是内层的div, res是后台返回的进度#}
                         if(num_progress == '99'){
                              console.log("come in 99")
                            clearInterval(sitv);
                            $('.progress-bar').css('width', '100%');
                            $('.progress-bar').text('100%');
                        }

                    });


                }, 10);                                 // 每10毫秒查询一次后台进度


            var thisurl = '/process_data'                      // 指当前页面的url
{#            var yourjson = '90'#}
            $.getJSON(thisurl, function(res){
            // ...

             console.log("sitv over res"+res)
                clearInterval(sitv);                   // 此时请求成功返回结果了,结束对后台进度的查询
            });

        })
})



</script>

2.3Python 后端进度条后端 逻辑代码

我这里使用的后端为Django, 使用别的后端思路相当。


2.3.1. URL.PY

设置两个url, 一个指向处理数据的的函数,另一个指向请求进度的函数

你可以看到还有一个 ,那个是 UI 展示的, 你可以把源码下载下来,部署一下程序然后就可以运行了. 

 

 

 

2.3.2 views.py

用全局变量记录处理进度,process_data函数负责具体任务,同时更新后台进度值,show_progress负责将当前进度值返回给前端。这里用了 全局变量  global num_progress

#encoding=utf-8

from django.http import JsonResponse
from django.shortcuts import render
import time


num_progress = 0 # 当前的后台进度值(不喜欢全局变量也可以很轻易地换成别的方法代替)




'''
展示界面 UI
'''
def show_progress1(request):
    # return JsonResponse(num_progress, safe=False)
    return render(request, 'datahexun.html')



'''
后台实际处理程序
'''
def process_data(request):
    # ...
    global num_progress

    for i in range(12345666):
        # ... 数据处理业务
        num_progress = i * 100 / 12345666; # 更新后台进度值,因为想返回百分数所以乘100
        # print 'num_progress=' + str(num_progress)
        # time.sleep(1)
        res = num_progress
        # print 'i='+str(i)
        # print 'res----='+str(res)
    return JsonResponse(res, safe=False)

'''
前端JS需要访问此程序来更新数据
'''
def show_progress(request):
    print 'show_progress----------'+str(num_progress)
    return JsonResponse(num_progress, safe=False)

 

此程序到此结束 . 至于如何运行 django 程序请百度一下. 此源码已经开源. 源码链接: https://github.com/chaoren399/progress_bar_demo

  • 11
    点赞
  • 66
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
首先,我们需要安装Djangodjango-widget-tweaks: ``` pip install django pip install django-widget-tweaks ``` 接下来,创建Django项目和应用程序: ``` django-admin startproject progress_bar_project cd progress_bar_project python manage.py startapp progress_bar ``` 在`progress_bar`应用程序中创建一个模型: ```python from django.db import models class Task(models.Model): name = models.CharField(max_length=100) progress = models.IntegerField(default=0) ``` 然后,我们需要创建一个视图函数来处理进度条更新。在`progress_bar/views.py`中添加以下代码: ```python from django.shortcuts import render from django.http import JsonResponse from django.views.decorators.csrf import csrf_exempt from .models import Task @csrf_exempt def update_progress(request): if request.method == 'POST': task_id = request.POST.get('task_id') progress = request.POST.get('progress') task = Task.objects.get(id=task_id) task.progress = progress task.save() return JsonResponse({'success': True}) ``` 在这个视图函数中,我们使用`JsonResponse`来返回一个JSON格式的响应,通知前端进度条已经更新成功。 接下来,我们需要创建一个模板来渲染进度条。在`progress_bar/templates`目录下创建一个名为`progress_bar.html`的文件,并添加以下代码: ```html {% load widget_tweaks %} {% block content %} <h1>Progress Bar</h1> <form method="POST" id="progress-form"> {% csrf_token %} <input type="hidden" name="task_id" value="{{ task.id }}"> <div class="progress"> <div class="progress-bar" role="progressbar" aria-valuenow="{{ task.progress }}" aria-valuemin="0" aria-valuemax="100" style="width: {{ task.progress }}%;"> {{ task.progress }}% </div> </div> <br> <div class="form-group"> {% render_field progress|add_class:"form-control-range" %} </div> <button type="submit" class="btn btn-primary">Update Progress</button> </form> <script> $(function() { $('#progress-form').submit(function(event) { event.preventDefault(); $.ajax({ type: 'POST', url: '{% url "update_progress" %}', data: $(this).serialize(), success: function(response) { if (response.success) { alert('Progress updated successfully!'); } } }); }); }); </script> {% endblock %} ``` 在这个模板中,我们使用Django Widget Tweaks来渲染进度条的表单元素。我们还使用jQuery和Ajax来处理进度条更新。当用户提交表单时,我们将进度值发送到服务器上的`update_progress`视图函数进行处理。 最后,我们需要创建一个URL路由来将请求发送到`update_progress`视图函数。在`progress_bar/urls.py`中添加以下代码: ```python from django.urls import path from . import views urlpatterns = [ path('update_progress/', views.update_progress, name='update_progress'), ] ``` 现在我们已经完成了进度条的管理功能,可以生成代码并运行Django应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值