打开CSV文件下载HTML

问题描述:

只是想知道如果有一种方法来打开浏览器中的CSV文件,而不是被下载?打开CSV文件下载HTML

我的代码:

<a href="Myfile.csv">Open</a> 
+0

的可能的复制[在PHP替代下载csv文件的获取它在浏览器中打开】(http://stackoverflow.com/questions/16188329/in-下载-CSV文件中的php-INSTEAD-OF--IT-得到开合的浏览器) –

+0

不,它不是因为我需要它在HTML – SMH

+0

要显示你的CSV浏览器?为什么不把它作为文本发送呢? – Brad

用这样的代码:<a href="Myfile.csv">Open</a>,你真的没有做任何下载。但是,如果客户端浏览器无法读取/呈现文件(本例中为.csv文件),则会强制用户下载文件。要明确实施下载,您必须设置header以告知浏览器如何处理“问题中的文件”请求。考虑这种过于简单的脚本:

PHP脚本:包含HTML标记

<?php // NOTICE THAT THERE IS NO WHITE-SPACE OR OUTPUT BEFORE <?php 
     // AND ALSO; NO "echo" STATEMENT AT ALL BEFORE THE if(isset()){} BLOCK. 

     if(isset($_GET['d'])){ 
      $file = htmlspecialchars(trim($_GET['d'])); 
      processDownload($file); 
     } 

     function processDownload($fileName) { 
      if($fileName){ 
       $dldFile = $fileName; 
       if(file_exists($fileName)){ 
        $size  = @filesize($fileName); 
        header('Content-Description: File Transfer'); 
        header('Content-Type: application/octet-stream'); 
        header('Content-Disposition: attachment; filename=' . $fileName); 
        header('Content-Transfer-Encoding: binary'); 
        header('Connection: Keep-Alive'); 
        header('Expires: 0'); 
        header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); 
        header('Pragma: public'); 
        header('Content-Length: ' . $size); 
        return TRUE; 
       } 
      } 
      return FALSE; 
     } 

    ?> 


    <!DOCTYPE html> 
    <html lang="en"> 
     <head> 
      <meta charset="UTF-8"> 
      <title>Download Example</title> 
     </head> 
     <body> 
      <div class="container"> 
       <div class="col-md-12"> 
        <!-- Myfile.csv IS IN THE SAME DIRECTORY AS THIS FILE: index.php --> 
        <!-- OTHERWISE; SET THE PATH TO THE CSV FILE AS VALUE OF d --> 
        <!-- NOTICE THAT THE LINK TO DOWNLOAD HERE IS THE SAME URL --> 
        <!-- WITH A QUERY PARAMETER ?d=Myfile.csv APPENDED TO IT.--> 
        <a href="index.php?d=Myfile.csv">Download CSV</a> 
       </div> 
      </div> 
     </body> 
    </html> 

人们希望,这可能给你如何去它自己的方式线索。

好运和欢呼声;-)

您必须添加下面的头。

header ('Content-Type: text/csv'); 

header ('Content-Type: text/csv'); 

OR

设置的iframe,并把您的CSV文件的URL在里面。

+0

报头(“内容-disposition:attachment; filename =“put_your_preferred_file_name_here.csv”');' - 将强制下载csv类型文件。 – Naga

+0

你说得对。我已经更新了我的答案。 @NagarajanPerumal:选中[这一点](http://stackoverflow.com/questions/6544382/csv-file-browser-opens-it-instead-of-downloading)也。那是什么? – Virb

+0

好。但我没有投下你的答案! – Naga