我所经历的大文件数据导出(后台执行,自动生成)
excel导出分成两部分内容:生成excel文件和下载excel文件 excel的文件生成在程序后台执行,前端不必等待,可进行其他后台操作 增加下载文件页面,显示excel文件生成的进度,完成后,方可下载生成的excel文件 文件生成后,点击下载方可下载相应的文件


<spanmicrosoft yahei><span> 1</span><span>$struserdata</span> = Eof <span> 2</span> 3 xmlns:x="urn:schemas-microsoft-com:office:excel" <span> 4</span> xmlns="http://www.w3.org/TR/REC-html40"> <span> 5</span><span> 6</span> span>PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <span> 7</span> <span> 8</span> <span> 9</span> <meta http-equiv="Content-type" c> <span>10</span> <style> <span>11 </style> <span>12</span> <span>13</span> <span>14</span> <div align="center" x:publishsource="Excel"> <span>15</span><span>16</span> <table x:str border="1" cellpadding="0" cellspacing="0" width="100%"> <span>17</span> Eof;<spanmicrosoft yahei>View Code<p><spanmicrosoft yahei> 文件的结尾:</spanmicrosoft></p> <div><spanmicrosoft yahei><img src="/static/imghw/default1.png" data-src="http://image.codes51.com/Article/image/20150810/20150810094650_3369.gif" class="lazy" alt=""><img src="/static/imghw/default1.png" data-src="http://image.codes51.com/Article/image/20150810/20150810094650_3369.gif" class="lazy" alt=""><p></p> <pre class="brush:php;toolbar:false"><spanmicrosoft yahei><span>1</span><span>$struserdata</span> = Eof <span>2</span> </spanmicrosoft>
场景:
用户点击 生成excel后,跳转到下载页面,程序在后台执行,用户可不必等待生成完成,可执行其他操作;
下载页面可看到文件生成的进度以及是否可下载状态
思路:
点击 生成excel,显示下载页面 ---> show_download方法
生成excel ---> create_excel 方法
<spanmicrosoft yahei><span>1</span><span>//</span><span> $cmd = "/usr/bin/php /home/xxx/xxx.php " . $strjoin . " >/dev/null & "; </span><span>2</span><span> // $a=exec($cmd, $out, $returndata);</span><span>3</span><span>4</span><span>5</span><span>$command</span> = "/usr/bin/php ".STATISTIC_EXPORT_SCRIPT_DIR."xxx.php " . "'" .<span>$strjoin</span> ."'". " " . <span>$uid</span> . " ". <span>$action</span> ." & "<span>; </span><span>6</span><span>$process</span> = <span>proc_open</span>(<span>$command</span>, <span>array</span>(),<span>$pipes</span><span>); </span><span>7</span><span>$var</span> = <span>proc_get_status</span>(<span>$process</span><span>); </span><span>8</span><span>proc_close</span>(<span>$process</span><span>); </span><span>9</span><span>$pid</span> = <span>intval</span>(<span>$var</span>['pid'])+1;</spanmicrosoft>
<spanmicrosoft yahei><span>1</span><span>set_time_limit</span>(0); <span>//</span><span>取消脚本运行时间的超时上限</span><span>2</span><span>3</span><span>ignore_user_abort</span>(<span>TRUE</span>); <span>//</span><span>后台运行,不受用户关闭浏览器的影响</span></spanmicrosoft>
<spanmicrosoft yahei><span>1</span><span>$statistic</span> = <span>call_user_func</span>(<span>array</span>('shellscript','get_result'),<span>$url</span>,<span>$params</span><span>); </span><span>2</span><span>if</span>(!<span>is_object</span>(<span>$statistic</span>) || !<span>isset</span>(<span>$statistic</span>->data-><span>items)){ </span><span>3</span><span>usleep</span>(400000);<span>//</span><span>停止400毫秒</span><span>4</span><span>$statistic</span> = <span>call_user_func</span>(<span>array</span>('shellscript','get_result'),<span>$url</span>,<span>$params</span><span>); </span><span>5</span> }</spanmicrosoft>
第一次请求api的时候,根据返回的total总数,以及pagesize,确定要请求的次数count; 这样便可知道要请求api的次数(分页请求api),在写入数据文件的同时,同时写入进度文件flag_data.xsl;
数据格式大约是(以逗号分割)
1,5
2,5
...然后显示文件进度的时候,读取进度文件,这样变可知道数据文件大体的进度 前端js处理时,几秒读取一次相应的方法(如果都100%进度,可停止请求方法),从而实现动态查看文件的生成进度


<spanmicrosoft yahei><span> 1</span><span>public</span><span>function</span><span> execscript_process(){ </span><span> 2</span><span>$this</span>->load->library('smarty'<span>); </span><span> 3</span><span>$file_arr_str</span> = <span>array</span><span>(); </span><span> 4</span><span>$file_arr_process</span> = <span>array</span><span>(); </span><span> 5</span><span>$file_arr_name</span> = <span>array</span><span>(); </span><span> 6</span><span>$file_arr</span> = <span>array</span><span>(); </span><span> 7</span><span>$refresh_flag</span> = 'yes'<span>; </span><span> 8</span><span>$uid</span> = <span>$_REQUEST</span>['uid'<span>]; </span><span> 9</span><span>$url_dir</span> = STATISTIC_EXPORT_FILE_DIR.<span>$uid</span> .'/';<span>//</span><span>@todo</span><span>10</span><span>if</span>(!<span>is_dir</span>(<span>$url_dir</span><span>)){ </span><span>11</span> @<span>mkdir</span>(<span>$url_dir</span>,0777<span>); </span><span>12</span><span> } </span><span>13</span><span>$files</span> = <span>scandir</span>(<span>$url_dir</span><span>); </span><span>14</span><span>15</span><span>if</span>(!<span>empty</span>(<span>$files</span><span>)){ </span><span>16</span><span>foreach</span> (<span>$files</span><span>as</span><span>$key</span> => <span>$value</span><span>) { </span><span>17</span><span>if</span>(<span>$value</span>!='.' && <span>$value</span>!='..'<span>){ </span><span>18</span><span>if</span>(<span>substr</span>(<span>$value</span>, 0 , 5)=="flag_"<span>){ </span><span>19</span><span>$file_size</span> = <span>filesize</span>(<span>$url_dir</span> . <span>$value</span><span>); </span><span>20</span><span>if</span>(!<span>empty</span>(<span>$file_size</span><span>)){ </span><span>21</span><span>$fhandle</span> = <span>fopen</span>(<span>$url_dir</span> . <span>$value</span>, 'rb+'<span>); </span><span>22</span><span>fseek</span>(<span>$fhandle</span>, -1,<span> SEEK_END); </span><span>23</span><span>$fstr</span> = ''<span>; </span><span>24</span><span>while</span>((<span>$c</span> = <span>fgetc</span>(<span>$fhandle</span>)) !== <span>false</span><span>) { </span><span>25</span><span>if</span>(<span>$c</span> == "\n" && <span>$fstr</span>) <span>break</span><span>; </span><span>26</span><span>$fstr</span> = <span>$c</span> . <span>$fstr</span><span>; </span><span>27</span><span>fseek</span>(<span>$fhandle</span>, -2,<span> SEEK_CUR); </span><span>28</span><span> } </span><span>29</span><span>fclose</span>(<span>$fhandle</span><span>); </span><span>30</span><span>$fstr</span> = <span>trim</span>(<span>$fstr</span><span>); </span><span>31</span><span>$fstr_arr_str</span> = <span>explode</span>(',', <span>$fstr</span><span>); </span><span>32</span><span>$file_arr_process</span>[] = 100 * <span>number_format</span>(<span>$fstr_arr_str</span>[0]/<span>$fstr_arr_str</span>[1],2).'%'<span>; </span><span>33</span><span>$file_arr_name</span>[] = <span>substr</span>(<span>$value</span>,5<span>); </span><span>34</span><span> } </span><span>35</span><span> } </span><span>36</span><span> } </span><span>37</span><span> } </span><span>38</span><span>39</span><span>foreach</span> (<span>$file_arr_process</span><span>as</span><span>$key</span> => <span>$value</span><span>) { </span><span>40</span><span>if</span>(<span>$value</span> != '100%'<span>){ </span><span>41</span><span>$refresh_flag</span> = 'no'<span>; </span><span>42</span><span>break</span><span>; </span><span>43</span><span> } </span><span>44</span><span> } </span><span>45</span><span> } </span><span>46</span><span>47</span><span>$file_arr</span> = <span>array</span><span>( </span><span>48</span> 'process' => <span>$file_arr_process</span>, <span>49</span> 'name' => <span>$file_arr_name</span>, <span>50</span> 'refresh_flag' => <span>$refresh_flag</span><span>51</span><span> ); </span><span>52</span><span>$file_arr_json</span> = json_encode(<span>$file_arr</span><span>); </span><span>53</span><span>echo</span><span>$file_arr_json</span><span>; </span><span>54</span> }</spanmicrosoft>
<spanmicrosoft yahei><span> 1</span><span>public</span><span>function</span><span> execscript_download(){ </span><span> 2</span><span>$filename</span> = <span>$_REQUEST</span>['filename'<span>]; </span><span> 3</span><span>$uid</span> = <span>$_REQUEST</span>['uid'<span>]; </span><span> 4</span><span>$file_dir</span> = STATISTIC_EXPORT_FILE_DIR.<span>$uid</span>.'/'.<span>$filename</span><span>; </span><span> 5</span><span>if</span> (!<span>file_exists</span>(<span>$file_dir</span><span>)){ </span><span> 6</span><span>header</span>("Content-type: text/html; charset=utf-8"<span>); </span><span> 7</span><span>echo</span> "File not found!"<span>; </span><span> 8</span><span>exit</span><span>; </span><span> 9</span> } <span>else</span><span> { </span><span>10</span><span>ini_set</span>("memory_limit","500M"<span>); </span><span>11</span><span>header</span>('Content-Description: File Transfer'<span>); </span><span>12</span><span>header</span>('Content-Type: application/octet-stream'<span>); </span><span>13</span><span>header</span>('Content-Disposition: attachment; filename='.<span>basename</span>(<span>$file_dir</span><span>)); </span><span>14</span><span>header</span>('Content-Transfer-Encoding: binary'<span>); </span><span>15</span><span>header</span>('Expires: ' . <span>gmdate</span>('D, d M Y H:i:s') . ' GMT'<span>); </span><span>16</span><span>header</span>('Cache-Control: must-revalidate,post-check=0, pre-check=0'<span>); </span><span>17</span><span>header</span>('Pragma: public'<span>); </span><span>18</span><span>header</span>('Content-Length: ' . <span>filesize</span>(<span>$file_dir</span><span>)); </span><span>19</span><span>readfile</span>(<span>$file_dir</span><span>); </span><span>20</span><span> } </span><span>21</span><span>22</span> }</spanmicrosoft>
现象描述:
当在后台点击生成文件,跳转到下载页的时候,因为下载页是显示文件进度的页面, 竟然出现有时候有刚刚点击的文件进度,有时候没有,就感觉没有生成相应的文件一样;
解决方法:
因为数据文件和进度文件都是生成在程序的某个文件夹file中,所以读取的时候都是读取的文件夹下的文件,从而判断显示进度;
后面才知道,由于后台程序有两台服务器,导致读取以及下载的时候找不到相应的文件夹,两个服务器相应的文件夹弄个共享目录就可以了
<spanmicrosoft yahei><span> 1</span><span>public</span><span>function</span><span> execscript_process_show(){ </span><span> 2</span><span>$this</span>->load->library('smarty'<span>); </span><span> 3</span><span>$uid</span> = <span>$_REQUEST</span>['uid'<span>]; </span><span> 4</span><span>$url_dir</span> = STATISTIC_EXPORT_FILE_DIR.<span>$uid</span> .'/';<span>//</span><span>@todo</span><span> 5</span><span>if</span>(!<span>is_dir</span>(<span>$url_dir</span><span>)){ </span><span> 6</span> @<span>mkdir</span>(<span>$url_dir</span>,0777<span>); </span><span> 7</span><span> } </span><span> 8</span><span>$files</span> = <span>scandir</span>(<span>$url_dir</span><span>); </span><span> 9</span><span>if</span>(!<span>empty</span>(<span>$files</span><span>)){ </span><span>10</span><span>foreach</span> (<span>$files</span><span>as</span><span>$key</span> => <span>$value</span><span>) { </span><span>11</span><span>if</span>(<span>$value</span>!='.' && <span>$value</span>!='..'<span>){ </span><span>12</span><span>foreach</span> (<span>$files</span><span>as</span><span>$key</span> => <span>$value</span><span>) { </span><span>13</span><span>if</span>(<span>$value</span>!='.' && <span>$value</span>!='..'<span>){ </span><span>14</span><span>if</span>(<span>substr</span>(<span>$value</span>, 0 , 5)!="flag_"<span>){ </span><span>15</span><span>$filenamedate</span> = <span>substr</span>(<span>$value</span>, 0,10<span>); </span><span>16</span><span>$today</span> = <span>date</span>('Y-m-d',<span>time</span><span>()); </span><span>17</span><span>$filenamedate</span> = <span>date</span>('Y-m-d',<span>strtotime</span>(<span>$filenamedate</span>)+(STATISTIC_FILE_EXPIRE_DAY-1)*24*3600<span>); </span><span>18</span><span>if</span>(<span>$today</span>><span>$filenamedate</span>){<span>//</span><span>文件过期</span><span>19</span> @<span>unlink</span>(<span>$url_dir</span> . <span>$value</span><span>); </span><span>20</span> @<span>unlink</span>(<span>$url_dir</span> . 'flag_' . <span>$value</span><span>); </span><span>21</span><span> } </span><span>22</span><span> } </span><span>23</span><span> } </span><span>24</span><span> } </span><span>25</span><span> } </span><span>26</span><span> } </span><span>27</span><span> } </span><span>28</span><span>29</span><span>$this</span>->smarty->assign('uid',<span>$uid</span><span>); </span><span>30</span><span>$this</span>->smarty->display('interact/statistic/execscript.tpl'<span>); </span><span>31</span> }</spanmicrosoft>
<spanmicrosoft yahei>http://blog.csdn.net/yysdsyl/article/details/4636457 http://www.codesky.net/article/201202/163385.html http://www.cnblogs.com/zdz8207/p/3765567.html http://blog.163.com/mojian20040228@126/blog/static/4112219320097300922992/ http://php.net/manual/en/features.commandline.php http://blog.csdn.net/yangjun07167/article/details/5603425 http://blog.csdn.net/yunsongice/article/details/5445448 http://www.cppblog.com/amazon/archive/2011/12/01/161281.aspx http://blog.51yip.com/tag/proc_open http://www.justwinit.cn/post/1418/ http://limboy.me/tech/2010/12/05/php-async.html</spanmicrosoft>
以上就介绍了我所经历的大文件数据导出(后台执行,自动生成),包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

如果在打开一份需要打印的文件时,在打印预览里我们会发现表格框线不知为什么消失不见了,遇到这样的情况,我们就要及时进行处理,如果你的打印文件里也出现了此类的问题,那么就和小编一起来学习下边的课程吧:excel打印表格框线消失怎么办?1、打开一份需要打印的文件,如下图所示。 2、选中所有需要的内容区域,如下图所示。 3、单击鼠标右键,选择“设置单元格格式”选项,如下图所示。 4、点击窗口上方的“边框”选项,如下图所示。 5、在左侧的线条样式中选择细实线图样,如下图所示。 6、选择“外边框”

在日常办公中经常使用Excel来处理数据,时常遇到需要使用“筛选”功能。当我们在Excel中选择执行“筛选”时,对于同一列而言,最多只能筛选两个条件,那么,你知道excel同时筛选3个以上关键词该怎么操作吗?接下来,就让小编为大家演示一遍。第一种方法是将条件逐步添加到筛选器中。如果要同时筛选出三个符合条件的明细,首先需要逐步筛选出其中一个。开始时,可以先根据条件筛选出姓“王”的员工。然后单击【确定】,接着在筛选结果中勾选【将当前所选内容添加到筛选器】。操作步骤如下所示。 同样,再次分别执行筛选

在我们日常的工作学习中,从他人处拷贝了Excel文件,打开进行内容添加或重新编辑后,再保存的有时候,有时会提示出现兼容性检查的对话框,非常的麻烦,不知道Excel软件,可不可改为正常模式呢?那么下面就由小编为大家带来解决这个问题的详细步骤,让我们一起来学习吧。最后一定记得收藏保存。1、打开一个工作表,在工作表的名称中显示多出来一个兼容模式,如图所示。2、在这个工作表中,进行了内容的修改后保存,结果总是弹出兼容检查器的对话框,很麻烦看见这个页面,如图所示。 3、点击Office按钮,点另存为,然

在处理数据时,有时我们会遇到数据包含了倍数、温度等等各种符号的时候,你知道excel上标应该如何设置吗?我们在使用excel处理数据时,如果不会设置上标,这可是会让我们的很多数据在录入时就会比较麻烦。今天小编就为大家带来了excel上标的具体设置方法。1.首先,让我们打开桌面上的MicrosoftOfficeExcel文档,选择需要修改为上标的文字,具体如图所示。2.然后,点击右键,在点击后出现的菜单中,选择“设置单元格格式”选项,具体如图所示。3.接下来,在系统自动弹出来的“单元格格式”对话框

大部分用户使用Excel都是用来处理表格数据的,其实Excel还有vba程序编写,这个除了专人士应该没有多少用户用过此功能,在vba编写时常常会用到iif函数,它其实跟if函数的功能差不多,下面小编给大家介绍下iif函数的用法。Excel中SQL语句和VBA代码中都有iif函数。iif函数和excel工作表中的IF函数用法相似,执行真假值判断,根据逻辑计算的真假值,返回不同结果。IF函数用法是(条件,是,否)。VBA中的IF语句和IIF函数,前者IF语句是控制语句可以根据条件执行不同的语句,后者

在软件的学习中,我们习惯用excel,不仅仅是因为需要方便,更因为它可以满足多种实际工作中需要的格式,而且excel运用起来非常的灵活,有种模式是方便阅读的,今天带给大家的就是:excel阅读模式在哪里设置。1、打开电脑,然后再打开Excel应用,找到目标数据。2、要想在Excel中,设置阅读模式,有两种方式。第一种:Excel中,有大量的便捷处理方式,分布在Excel中布局中。在Excel的右下角,有设置阅读模式的快捷方式,找到十字标志的图案,点击即可进入阅读模式,在十字标志的右边有一个小的三

1、打开PPT,翻页至需要插入excel图标的页面。点击插入选项卡。2、点击【对象】。3、跳出以下对话框。4、点击【由文件创建】,点击【浏览】。5、选择需要插入的excel表格。6、点击确定后跳出如下页面。7、勾选【显示为图标】。8、点击确定即可。

我们在处理数据、表格、图表等等各种工作都会用到MicrosoftOfficeExcel,但在使用MicrosoftOfficeExcel时,有时我们会发现无法输入内容了,提示我们“输入值非法”。你知道excel输入值非法如何取消限定吗?让小编来为大家演示一遍。首先,让我们仔细观察案发现场的高清图片。当我们在C1单元格输入内容时,只需按下回车键,就会看到上述提示。 2.取消之后回到电子表格页面,选中C1单元格,此时可能有些人会发现C1单元格的右下角有一个下拉的小三角符号,如图所示,其实问题就处在
