目录
回复讨论(解决方案)
首页 后端开发 php教程 php 导入导出怎么做成有进度条??

php 导入导出怎么做成有进度条??

Jun 23, 2016 pm 02:23 PM

我要做导入导出功能,为了界面友好,提示时想出线进度条显示进度,但我不知道怎么做!
我的导入是导入csv格式的文件,直接读取,然后 insert into 数据表中,导出也是直接查询生成csv格式文件,
我能做了一个进度条,但是不知道怎么来获取导入导出执行的进度,然后再通过ajax及js更新我的进度条。


回复讨论(解决方案)

客户端支持,通过
sliverlight,flash,html5

或者服务器端,你查apc扩展,,好像还一个,忘记名字了

这个用ajax很容易实现,你可以查下相关资料

假如有100个操作,你可以让第一个操作前进1,第二个操作前进3 ...

我建议不要做这个进度条效果,因为可能影响速度
只要弄一个"导入中"

使用缓存输出吧


// 省略其他html+js进度条代码$i = 0;while($i<100) {    // 执行内容    sleep(1);    // 根据总量和当前任务计算任务进度$i    $i = $i++;    echo '<script>进度条变更js到'.$i.'</script>';    ob_flash()    flash();}
登录后复制

<?php// 进度条演示代码,页面输出ob_start();header('Content-Type: text/html;charset=utf-8');echo '当前任务进度:<span id="p">0%</span>';echo str_repeat(' ', 4096);ob_flush();flush();// 执行任务$i = 0;while($i<100) {	    // 执行内容    sleep(1);    // 根据总量和当前任务计算任务进度$i    $i++;    echo '<script type="text/javascript">document.getElementById(\'p\').innerHTML = "'.$i.'%";</script>';    ob_flush();    flush();}
登录后复制

我以前做采集的时候写的,ie下有用,chrome下试了下进度不跑,懒得该了
http://devp.cosrc.com/scroll2.php

很不错,很强>>>

PHP code
// 省略其他html+js进度条代码
$i = 0;
while($i<100) {
// 执行内容
sleep(1);
// 根据总量和当前任务计算任务进度$i
$i = $i++;
echo '<script>进度条变更js到'.$i.'</script>';
ob_flash()
flash();
}
我会做进度条,关键是我不会这一步 “// 根据总量和当前任务计算任务进度$i”
我查询怎么做这一步呢?

引用 6 楼 hnxxwyq 的回复:
PHP code
// 省略其他html+js进度条代码
$i = 0;
while($i<100) {
// 执行内容
sleep(1);
// 根据总量和当前任务计算任务进度$i
$i = $i++;
echo '<script>进度条变更js到'.$i.'</script>';
ob_flash()
flash();
}

……

通常这种进度条是这样做的
先获取整体任务,然后以一个维度来量化,再随时取当前进度,除以整体的,再化整

比如一个文件内有x行要读入,那么虽然每行内容大小不一,但可以看做计算完每行算完成总体进度1/x

那么如果要每处理完一行,就要响应不断的查询和进行一个输出,会影响性能的,而且你的导入方式必须能够量化每一步

比如这样
$file_size=文件内数据行数;
$current=0; //第一行,开始

while (没处理完)
{
导入一行;
$current++;
输出 $current/$file_size * 100;
//继续
}

显而易见,这得你的处理是逐步的....如果你是用某种现成的直接导入导出文件的函数,你根本不会获取到中间执行的过程.






引用 6 楼 hnxxwyq 的回复:
PHP code
// 省略其他html+js进度条代码
$i = 0;
while($i<100) {
// 执行内容
sleep(1);
// 根据总量和当前任务计算任务进度$i
$i = $i++;
echo '<script>进度条变更js到'.$i.'</script>';
ob_flash()
flash();
}

……

导入时,你可以计算下csv的总行数n,然后每次固定读取m行(可以根据你的认为的效率修正),每次处理m行,则记录一次执行任务次数i,最后的进度比就是 floor(i*m / n) * 100;

伪代码

<?php$n = '总任务量';$m = '批次任务执行量';$i = 0;while($i * $m < $n) {    // 处理m个执行量的内容       // 统计执行任务量    $total = ++$i * $m;    // 计算进度比    $p = floor(min($total, $n) / $n);}
登录后复制

引用 10 楼 wxhbbdd 的回复:

引用 6 楼 hnxxwyq 的回复:
PHP code
// 省略其他html+js进度条代码
$i = 0;
while($i // 执行内容
sleep(1);
// 根据总量和当前任务计算任务进度$i
$i = $i++;
echo '<script>进度条变更js到'.$i.'</script>';
ob……



$n = '总任务量';
$m = '批次任务执行量';
$i = 0;

while($i * $m      // 处理m个执行量的内容
   
    // 统计执行任务量
    $total = ++$i * $m;

    // 计算进度比
    $p = floor(min($total, $n) / $n * 100); // 少乘了个100
}

APC实现方法:
 
安装APC,参照官方文档安装,可以使用PECL模块安装方法快速简捷,这里不说明
配置php.ini,设置参数 apc.rfc1867=1 ,使APC支持上传进度条功能,在APC源码说明文档里面有说明
代码范例: 
if ($_SERVER['REQUEST_METHOD'] == 'POST') {  //上传请求
    $status = apc_fetch('upload_' . $_POST['APC_UPLOAD_PROGRESS']);
    $status['done'] = 1;
    echo json_encode($status);  //输出给用户端页面里的ajax调用,相关文档请自己寻找
    exit;
} elseif (isset($_GET['progress_key'])) {   //读取上传进度
    $status = apc_fetch('upload_'.$_GET['progress_key']);
    echo json_encode($status);
    exit;
} else {
    //其他代码,比如上传表单等
}

uploadprogress 模块实现方法:
使用PECL模块安装方法安装该模块
php.ini里面设置 uploadprogress.file.filename_template = “/tmp/upd_%s.txt”
代码范例: 
if($_SERVER['REQUEST_METHOD']=='POST') {
    if (is_uploaded_file($_FILES['upfile']['tmp_name'])) {
        $upload_dir = 'your_path/';
        $ext        = strrchr($_FILES['video']['name'], '.');
        $sessid     = $_POST['UPLOAD_IDENTIFIER'] ;
        $tmpfile    = $upload_dir . $sessid;  
        $sessfile   = $upload_dir . $sessid .$ext;
        if (move_uploaded_file($_FILES['upfile']['tmp_name'],$tmpfile)) {
            //上传成功
        } else {
            //上传失败
    } else {
        //上传错误
        
} elseif (!empty($_GET['sessid'])) {
    header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
    header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
    header("Cache-Control: no-store, no-cache, must-revalidate");
    header("Cache-Control: post-check=0, pre-check=0", false);
    header("Pragma: no-cache");
    header("Content-Type:text/html;charset=UTF-8");
 
    $unique_id = $_GET['sessid'];
    $uploadvalues = uploadprogress_get_info($unique_id);
 
    if (is_array($uploadvalues)) {
        echo json_encode($uploadvalues);
    } else {
        //读取进度失败,另外处理逻辑
    }
    
} else {
    //显示上传表单
}

收藏 留名~~~

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1674
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
说明PHP中的安全密码散列(例如,password_hash,password_verify)。为什么不使用MD5或SHA1? 说明PHP中的安全密码散列(例如,password_hash,password_verify)。为什么不使用MD5或SHA1? Apr 17, 2025 am 12:06 AM

在PHP中,应使用password_hash和password_verify函数实现安全的密码哈希处理,不应使用MD5或SHA1。1)password_hash生成包含盐值的哈希,增强安全性。2)password_verify验证密码,通过比较哈希值确保安全。3)MD5和SHA1易受攻击且缺乏盐值,不适合现代密码安全。

PHP类型提示如何起作用,包括标量类型,返回类型,联合类型和无效类型? PHP类型提示如何起作用,包括标量类型,返回类型,联合类型和无效类型? Apr 17, 2025 am 12:25 AM

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。

PHP和Python:解释了不同的范例 PHP和Python:解释了不同的范例 Apr 18, 2025 am 12:26 AM

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

您如何防止PHP中的SQL注入? (准备的陈述,PDO) 您如何防止PHP中的SQL注入? (准备的陈述,PDO) Apr 15, 2025 am 12:15 AM

在PHP中使用预处理语句和PDO可以有效防范SQL注入攻击。1)使用PDO连接数据库并设置错误模式。2)通过prepare方法创建预处理语句,使用占位符和execute方法传递数据。3)处理查询结果并确保代码的安全性和性能。

PHP和Python:代码示例和比较 PHP和Python:代码示例和比较 Apr 15, 2025 am 12:07 AM

PHP和Python各有优劣,选择取决于项目需求和个人偏好。1.PHP适合快速开发和维护大型Web应用。2.Python在数据科学和机器学习领域占据主导地位。

PHP:处理数据库和服务器端逻辑 PHP:处理数据库和服务器端逻辑 Apr 15, 2025 am 12:15 AM

PHP在数据库操作和服务器端逻辑处理中使用MySQLi和PDO扩展进行数据库交互,并通过会话管理等功能处理服务器端逻辑。1)使用MySQLi或PDO连接数据库,执行SQL查询。2)通过会话管理等功能处理HTTP请求和用户状态。3)使用事务确保数据库操作的原子性。4)防止SQL注入,使用异常处理和关闭连接来调试。5)通过索引和缓存优化性能,编写可读性高的代码并进行错误处理。

PHP的目的:构建动态网站 PHP的目的:构建动态网站 Apr 15, 2025 am 12:18 AM

PHP用于构建动态网站,其核心功能包括:1.生成动态内容,通过与数据库对接实时生成网页;2.处理用户交互和表单提交,验证输入并响应操作;3.管理会话和用户认证,提供个性化体验;4.优化性能和遵循最佳实践,提升网站效率和安全性。

在PHP和Python之间进行选择:指南 在PHP和Python之间进行选择:指南 Apr 18, 2025 am 12:24 AM

PHP适合网页开发和快速原型开发,Python适用于数据科学和机器学习。1.PHP用于动态网页开发,语法简单,适合快速开发。2.Python语法简洁,适用于多领域,库生态系统强大。

See all articles