php导入csv 进度条,php 导入导出怎么做成有进度条??
我要做导入导出功能,为了界面友好,提示时想出线进度条显示进度,但我不知道怎么做!
我的导入是导入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 导入导出怎么做成有进度条??相关推荐
- mysql linux导入csv主键,MySQL导入csv文件内容到Table及数据库的自增主键设置
写在前面 目的是测试将csv文件内容导入到表中, 同时记录一下自增主键的设置. 测试采用MySQL8.0. 新建表customer_info如下, 未设置主键. 修改上表, 添加主键id, 并设置为自 ...
- python导入csv文件-python如何导入csv文件格式
1.通过标准的Python库导入CSV文件 Python提供了一个标准的类库CSV文件.这个类库中的reader()函数用来导入CSV文件.当CSV文件被读入后,可以利用这些数据生成一个NumPy数组 ...
- python导入csv文件-python如何导入csv
1.通过标准的Python库导入CSV文件 Python提供了一个标准的类库CSV文件.这个类库中的reader()函数用来导入CSV文件.当CSV文件被读入后,可以利用这些数据生成一个NumPy数组 ...
- mysql导入csv数据慢_mysql导入数据过慢 解决办法
mysql导入数据过慢 解决方法 mysql中用 mysql->use test; mysql->set names utf8; mysql->source D:/ceshi.sql ...
- hbase导入csv文件_HBase 数据导入 ImportTsv
ImportTsv 工具是通过map reduce 完成的.所以要启动yarn. 工具要使用jar包,所以注意配置classpath.ImportTsv默认是通过hbase api 插入数据的 [ha ...
- python导入csv报错_Python 导入csv报错的解决办法
日常做分析导数据源进python,有时候会出现报错及显示乱码的问题,今天来梳理一下常见的报错. python 代码 import pandas as pd import numpy as np df= ...
- mysql导入csv文件 第一行有问题_mysql 导入 csv文件中数据,只能导入第一行
用workbench导入csv数据,只能导入数据的第一行,也就是标注每一列的列名的那一行. 但问题是,每次导入完成时,系统提示已经导入了500条记录(这个文件中的确有500条记录),可是刷新数据库后打 ...
- python操作sqlite3 导入csv文件_[转载]SQLite 3导入导出成txt或csv操作
平时使用官方提供的sqlite3.exe工具来操作 sqlite的数据库,可以在网上下到. 进入管理: sqlite3.exe d:\\test.db //假设数据是 d:\\test.db > ...
- mysql数据导入导出 CSV格式_MySQL中导入导出CSV格式数据
原标题:MySQL中导入导出CSV格式数据 预备阅读:MySQL中的主键问题和赋权限问题 今天来讲一下在MySQL中导入和导出CSV格式数据的操作. CSV格式数据 逗号分隔值(Comma-Separ ...
最新文章
- VRPM包安装失败解决方案:had non-zero exit status
- CentOS6.5_64下 nginx+uwsgi+Python +多站点环境搭建
- Sencha Touch2 -- 11.1:定义具有关联关系的模型
- 中国移动携手华为完成5G话音的全部功能测试
- JavaScript汉字Unicode编码相互转换
- Java机器学习开发库
- linux系统怎样挂载虚拟盘,linux 应用盘(从盘)挂载方法linux操作系统 -电脑资料...
- 电脑如何通过USB连接PPC手机上网
- 4k hidpi 黑苹果_【图片】为了让Mac pro也实现hidpi 把4k的分辨率显示成到1920,我今天也是拼了,下午研究了半天【macpro吧】_百度贴吧...
- 计算机主机显示接口,一文了解电脑视频接口 看完彻底明白了
- tail关键字查询日志
- 搭建一个可视化看板,仅需 4 步
- 北京航空航天大学计算机学院院长,胡勇 中文主页 北京航空航天大学教师个人主页系统...
- 腾讯地图位置服务器,腾讯位置服务离线地图接入指南
- 牛人在chinaren上的经典歌曲集
- Linux学习笔记-shell脚本-log脚本函数
- 【建议收藏】这个工具专门用于寻找路由器中的安全漏洞.md
- 物联网无线技术具体是怎么分类的,主要的应用场景是什么?
- (一)利用Wikipedia中文语料训练词向量word2vec——获取Wikipedia简体中文语料库
- ns3 Traffic Control Layer解读