我要做导入导出功能,为了界面友好,提示时想出线进度条显示进度,但我不知道怎么做!

我的导入是导入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 ''; ob_flash() flash();}

0%';echo str_repeat(' ', 4096);ob_flush();flush();// 执行任务$i = 0;while($i<100) { // 执行内容 sleep(1); // 根据总量和当前任务计算任务进度$i $i++; echo ''; 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 '';

ob_flash()

flash();

}

我会做进度条,关键是我不会这一步 “// 根据总量和当前任务计算任务进度$i”

我查询怎么做这一步呢?

引用 6 楼 hnxxwyq 的回复:

PHP code

// 省略其他html+js进度条代码

$i = 0;

while($i<100) {

// 执行内容

sleep(1);

// 根据总量和当前任务计算任务进度$i

$i = $i++;

echo '';

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 '';

ob_flash()

flash();

}

……

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

伪代码引用 10 楼 wxhbbdd 的回复:

引用 6 楼 hnxxwyq 的回复:

PHP code

// 省略其他html+js进度条代码

$i = 0;

while($i<100) {

// 执行内容

sleep(1);

// 根据总量和当前任务计算任务进度$i

$i = $i++;

echo '';

ob……

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 {

//显示上传表单

}

收藏 留名~~~

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

php导入csv 进度条,php 导入导出怎么做成有进度条??相关推荐

  1. mysql linux导入csv主键,MySQL导入csv文件内容到Table及数据库的自增主键设置

    写在前面 目的是测试将csv文件内容导入到表中, 同时记录一下自增主键的设置. 测试采用MySQL8.0. 新建表customer_info如下, 未设置主键. 修改上表, 添加主键id, 并设置为自 ...

  2. python导入csv文件-python如何导入csv文件格式

    1.通过标准的Python库导入CSV文件 Python提供了一个标准的类库CSV文件.这个类库中的reader()函数用来导入CSV文件.当CSV文件被读入后,可以利用这些数据生成一个NumPy数组 ...

  3. python导入csv文件-python如何导入csv

    1.通过标准的Python库导入CSV文件 Python提供了一个标准的类库CSV文件.这个类库中的reader()函数用来导入CSV文件.当CSV文件被读入后,可以利用这些数据生成一个NumPy数组 ...

  4. mysql导入csv数据慢_mysql导入数据过慢 解决办法

    mysql导入数据过慢 解决方法 mysql中用 mysql->use test; mysql->set names utf8; mysql->source D:/ceshi.sql ...

  5. hbase导入csv文件_HBase 数据导入 ImportTsv

    ImportTsv 工具是通过map reduce 完成的.所以要启动yarn. 工具要使用jar包,所以注意配置classpath.ImportTsv默认是通过hbase api 插入数据的 [ha ...

  6. python导入csv报错_Python 导入csv报错的解决办法

    日常做分析导数据源进python,有时候会出现报错及显示乱码的问题,今天来梳理一下常见的报错. python 代码 import pandas as pd import numpy as np df= ...

  7. mysql导入csv文件 第一行有问题_mysql 导入 csv文件中数据,只能导入第一行

    用workbench导入csv数据,只能导入数据的第一行,也就是标注每一列的列名的那一行. 但问题是,每次导入完成时,系统提示已经导入了500条记录(这个文件中的确有500条记录),可是刷新数据库后打 ...

  8. python操作sqlite3 导入csv文件_[转载]SQLite 3导入导出成txt或csv操作

    平时使用官方提供的sqlite3.exe工具来操作 sqlite的数据库,可以在网上下到. 进入管理: sqlite3.exe d:\\test.db //假设数据是 d:\\test.db > ...

  9. mysql数据导入导出 CSV格式_MySQL中导入导出CSV格式数据

    原标题:MySQL中导入导出CSV格式数据 预备阅读:MySQL中的主键问题和赋权限问题 今天来讲一下在MySQL中导入和导出CSV格式数据的操作. CSV格式数据 逗号分隔值(Comma-Separ ...

最新文章

  1. VRPM包安装失败解决方案:had non-zero exit status
  2. CentOS6.5_64下 nginx+uwsgi+Python +多站点环境搭建
  3. Sencha Touch2 -- 11.1:定义具有关联关系的模型
  4. 中国移动携手华为完成5G话音的全部功能测试
  5. JavaScript汉字Unicode编码相互转换
  6. Java机器学习开发库
  7. linux系统怎样挂载虚拟盘,linux 应用盘(从盘)挂载方法linux操作系统 -电脑资料...
  8. 电脑如何通过USB连接PPC手机上网
  9. 4k hidpi 黑苹果_【图片】为了让Mac pro也实现hidpi 把4k的分辨率显示成到1920,我今天也是拼了,下午研究了半天【macpro吧】_百度贴吧...
  10. 计算机主机显示接口,一文了解电脑视频接口 看完彻底明白了
  11. tail关键字查询日志
  12. 搭建一个可视化看板,仅需 4 步
  13. 北京航空航天大学计算机学院院长,胡勇 中文主页 北京航空航天大学教师个人主页系统...
  14. 腾讯地图位置服务器,腾讯位置服务离线地图接入指南
  15. 牛人在chinaren上的经典歌曲集
  16. Linux学习笔记-shell脚本-log脚本函数
  17. 【建议收藏】这个工具专门用于寻找路由器中的安全漏洞.md
  18. 物联网无线技术具体是怎么分类的,主要的应用场景是什么?
  19. (一)利用Wikipedia中文语料训练词向量word2vec——获取Wikipedia简体中文语料库
  20. ns3 Traffic Control Layer解读

热门文章

  1. PAT 1059 Prime Factors[难]
  2. 循环数组的动态规划问题
  3. Spring配置文件总结
  4. DOM2和DOM3读书笔记
  5. scala的list源码解密
  6. .net环境下ckeditor与ckfinder中文文件链接乱码的问题
  7. c# asp.net RangeValidator(范围验证)控件(11)
  8. 基于Nodejs的前端灰度发布方案_20190228
  9. JSON and Microsoft Technologies(翻译)
  10. centos7 hostnamectl