- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 phpexcel 的新手,所以我使用附加的代码将数据从数据库导出到 xls 文件。它在除 Chrome 之外的任何其他浏览器中都可以正常工作,其中下载的文件没有“扩展名”,而是 xls。我的代码有问题还是应该修改浏览器设置?有人能帮我吗?谢谢
文件已下载 [Inventário Livros (20-05-2015)-]
我的代码:
<?php
date_default_timezone_set("Atlantic/Cape_Verde");
require_once '../../assets/PHPExcel_1.8.0/Classes/PHPExcel.php';
require_once '../../assets/PHPExcel_1.8.0/Classes/PHPExcel/IOFactory.php';
$objPHPExcel = new PHPExcel();
$Archive = "Inventário Livros";
$date = date('d/m/Y');
require '../conexao/conexao.php';
$objPHPExcel->getProperties()
->setCreator("RELM")
->setLastModifiedBy("RELM")
->setTitle("Inventário Livros")
->setSubject("Inventário")
->setDescription("")
->setKeywords("")
->setCategory("");
$objPHPExcel->getDefaultStyle()->getFont()->setName('Calibri');
$objPHPExcel->getDefaultStyle()->getFont()->setSize(11);
$objPHPExcel->getActiveSheet()->getRowDimension('9')->setRowHeight(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(5);
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(9);
$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(40);
$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(30);
$objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(12);
$objPHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(12);
$objPHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(12);
//=======================================Cabeçalho do Doc==============================================//
$objPHPExcel->getActiveSheet()->setCellValue('C7', "Relação dos livros existentes na biblioteca");
$objPHPExcel->setActiveSheetIndex(0)->mergeCells('C7:F7');
$objPHPExcel->getActiveSheet()
->getStyle('C7:F7')
->getAlignment()
->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
$objPHPExcel->getActiveSheet()
->getStyle('C7:F7')
->getFont()
->setBold(true);
$objPHPExcel->getActiveSheet()
->getStyle('C7:F7')
->getFont()
->setSize(14);
//=======================================Imagem==============================================//
$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName('header');
$objDrawing->setDescription('Cabeçalho da pagina');
$objDrawing->setPath('../../images/header.png');
$objDrawing->setCoordinates('C1');
$objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
//=================================Conteudo(posiçao e estilo)==============================//
$y = 9;
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue("A" . $y, 'Nº')
->setCellValue("B" . $y, 'Estante')
->setCellValue("C" . $y, 'Obra')
->setCellValue("D" . $y, 'Autor')
->setCellValue("E" . $y, 'Categoria')
->setCellValue("F" . $y, 'Ano Esc.')
->setCellValue("G" . $y, 'Obs.');
$objPHPExcel->getActiveSheet()
->getStyle('A9:G9')
->getFill()
->setFillType(PHPExcel_Style_Fill::FILL_SOLID)
->getStartColor()->setARGB('FFEEEEEE');
$objPHPExcel->getActiveSheet()
->getStyle('A9:G9')
->getAlignment()
->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
$objPHPExcel->getActiveSheet()
->getStyle('A9:G9')
->getFont()
->setBold(true);
$objPHPExcel->getActiveSheet()
->getStyle('A9:G9')
->getFont()
->setSize(12);
$borders = array(
'borders' => array(
'allborders' => array(
'style' => PHPExcel_Style_Border::BORDER_THIN,
'color' => array('argb' => 'FF000000'),
)
),
);
$objPHPExcel->getActiveSheet()
->getStyle('A9:G9')
->applyFromArray($borders);
$query = "SELECT * FROM book AS B INNER JOIN category AS C ON B.category_id=C.id_category INNER JOIN scholarity AS S ON B.scholarity_id=S.id_scholarity ORDER BY number";
$res = mysql_query($query);
while ($row = mysql_fetch_array($res)) {
$y++;
$objPHPExcel->setActiveSheetIndex(0)
->getStyle('A' . $y . ":G" . $y)
->applyFromArray($borders);
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue("A" . $y, $row['number'])
->setCellValue("B" . $y, $row['shelf'])
->setCellValue("C" . $y, $row['title'])
->setCellValue("D" . $y, $row['author'])
->setCellValue("E" . $y, $row['category_name'])
->setCellValue("F" . $y, $row['scholarity_name'])
->setCellValue("G" . $y, $row['obs']);
}
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment; filename= "' . $Archive . ' (' . $date . ') " ');
header('Cache-Control: max-age-0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
$objWriter->save('php://output');
exit; ?>
最佳答案
您在响应中添加了一个 http header “Content-Disposition”。此 header 告诉 Chrome 浏览器和其他浏览器 ;-),浏览器应在其文件保存窗口中显示哪个文件名。只需将 .xls 添加到您的文件名中,浏览器就会使用它。
关于php - Chrome 正在导出错误的 "file extension"而不是 xls,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30349003/
我有一个问题,我想通过其他程序打开 chrome://extensions/页面,例如 cmd.exe 或其他程序。 我们知道,如果我们用chrome.exe打开一个网站,我们可以在cmd.exe中执
当您编写manifest.json 文件时,您必须为内容脚本指定匹配。 http 和 https 工作正常,但如果我尝试包含 chrome://*/* 或其任何变体,我会得到一个我尝试对我的匹配使用无
我真的很困惑我想制作一个可以扩展用户的Google日历的Chrome扩展程序,我应该在Google API下注册哪种程序? 它是Web App吗?但是我不打算让服务器托管任何东西,因为Chrome扩展
我想在带有chrome-extension://URL的iframe上运行内容脚本。我在我的manifest.json文件中添加了一行代码,该行是从http://code.google.com/chr
目前,我正在使用记事本和 chrome 控制台的组合对我的 google-chrome-extensions 进行编码。我 100% 确信有更好的方法来对这些扩展进行编程。人们使用什么环境? 最佳答案
在编写 manifest.json 文件时,必须指定 matches用于您的内容脚本。 http和 https工作正常,但如果我尝试包含 chrome://*/*或它的任何变体,我收到一个错误,提示我
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve
在发布更新后,我正在尝试为我的 Chrome 扩展程序的用户创造流畅的体验。 我在更新应用程序时重新注入(inject)了我的内容脚本,即使用户继续在扩展更新后未刷新的页面上使用我的扩展,我的功能仍然
将扩展程序从 Chrome 移植到 FF 遵循本教程(在 Chrome 中运行良好):http://www.codingscripts.com/check-whether-user-has-a-chr
我正在将 google-chrome 扩展改编成 firefox。 这个扩展相当简单,它只是重新加载当前浏览器窗口并在其中放置一个特定的字符串(它用于在 Odoo 上激活调试状态)。 但是,当我在 m
我正在尝试在普通 HTML 页面(非扩展)中链接到 chrome://extensions。但是单击链接不会执行任何操作: chrome://extensions 右键单击并在新选项卡中打开只会打开
为 String 编写扩展名很容易,但问题是它总是显示为 "MyString".ExtensionMethod() 如果这样写: public static class Extensions{
如题。我正在运行 Joomla 2.5。 “扩展”下拉菜单中唯一可见的项目是: 模块经理 插件管理器 模板管理器 语言经理 编辑:我这样做是为了安装模板,按照此页面上的说明:http://docs.j
基本上我希望文件名以扩展名列表中的扩展名结尾。这是我在 python 中的代码。我已经将一些示例文件名作为列表,如下所示: extensions = ['.mp3','.m4a','.wma'] fi
在 background.html : chrome.tabs.query({active:true, currentWindow:true},function(tabs){ chrome.tab
我有一个可能被用户禁用的 chrome 扩展。在这种情况下,我想创建一个指向 chrome://extensions 菜单的链接。它会是这样的 Chrome extensions 这是不允许的:不允许
我查看了 Google 文档,但不知道如何更改其类型。 这是我加载时遇到的错误。 尝试安装此扩展时出现警告:“browser_action”仅允许用于扩展程序,这是一个旧版打包应用程序。 这是我的ma
我有一个正在构建的 chrome 扩展,它使用 OAuth 访问许多 API。我没有将我的消费者 secret 存储在扩展程序中,而是重定向到获取 token 的服务器,然后重定向回我的扩展程序中的页
我有一个正在构建的 chrome 扩展,它使用 OAuth 访问许多 API。我没有将我的消费者 secret 存储在扩展程序中,而是重定向到获取 token 的服务器,然后重定向回我的扩展程序中的页
这个问题已经有答案了: Why would a developer place a forward slash at the start of each relative path? (4 个回答)
我是一名优秀的程序员,十分优秀!