热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何使用PHP代码将表格导出为UTF8格式的Excel文件

本文介绍了如何使用PHP代码将表格导出为UTF8格式的Excel文件。首先,需要连接到数据库并获取表格的列名。然后,设置文件名和文件指针,并将内容写入文件。最后,设置响应头部,将文件作为附件下载。

我写了PHP代码是为了在csv(excel)中导出一个表。
我的表格有6列:Timestamp,Order number,Last Name,First Name,Phone number,e-mail address.
字符集是utf8。
我的代码是:

$cOnn= mysqli_connect("localhost","username","password","database");
$filename = "FILENAME";
$fp = fopen('php://output','w');
$query = "SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA='mydatabase' AND TABLE_NAME='myTableName'";
$result = mysqli_query($conn,$query);
while ($row = mysqli_fetch_row($result)) {
$header[] = $row[0];
}
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
fputcsv($fp,$header);
$query = "SELECT * FROM `MyTableName` order by `LNAME`";
$result = mysqli_query($conn,$query);
while($row = mysqli_fetch_row($result)) {
fputcsv($fp,$row);
}
exit;
?>

因此,我有我的excel文件,但不幸的是,有些名称是用希腊语写的,我在导出文件中看到像"ΣΟΦΙΑ".这样的字符

有人可以帮我解决这个问题吗?


这是一个编码问题,请在标头中使用charset = UTF-8,如下所示:

替换此行:

header('Content-type: application/csv');

此行:

header("content-type:application/csv;charset=UTF-8");

,

谢谢,我尝试了一下但没有成功。
导出文件具有相同的结果。
我不是程序员,我对php和sql的了解很差。
但是我找到了一种解决方法。我尝试过:

$con = mysqli_connect("localhost","MyUsername","MyPassword","MyDatabase");
if (mysqli_connect_errno())
{
die('Could not connect: ' . mysqli_connect_error());
}
mysqli_select_db($con,"MyDatabase");
$sql = "SELECT * FROM `MyTableName` order by `LNAME`";
$result = mysqli_query($con,$sql);
while($row = mysqli_fetch_array($result))
{
echo ("

    ");
    echo ("
  • " . utf8_decode($row['LNAME']) . " " . utf8_decode($row['FNAME']) . " " . $row['PHONE'] . " " . utf8_decode($row['EMAIL'])."
  • ");
    echo ("
");
}
mysqli_close($con);
?>

因此,我得到一个网页列表,所有名称和字符均可读。
虽然,我无法考虑如何使用“ utf8_decode”来使csv文件具有相同的结果。
有什么想法吗?

,

您是否正在Excel中打开CSV文件?这篇文章介绍了如何向文件添加UTF-8字节顺序标记(BOM),以便Excel 2007和更高版本将正确识别编码:Microsoft Excel mangles Diacritics in .csv files?


推荐阅读
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 本文详细介绍了 MySQL 中 LAST_INSERT_ID() 函数的使用方法及其工作原理,包括如何获取最后一个插入记录的自增 ID、多行插入时的行为以及在不同客户端环境下的表现。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 探讨如何从数据库中按分组获取最大N条记录的方法,并分享新年祝福。本文提供多种解决方案,适用于不同数据库系统,如MySQL、Oracle等。 ... [详细]
  • 本文详细介绍了 MySQL 数据库中的基础操作,包括创建、查询、修改和删除数据库、表及数据的命令。通过具体的 SQL 语句示例,帮助读者快速掌握 MySQL 的基本操作。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 在成功安装和测试MySQL及Apache之后,接下来的步骤是安装PHP。为了确保安全性和配置的一致性,建议在安装PHP前先停止MySQL和Apache服务,并将MySQL集成到PHP中。 ... [详细]
author-avatar
陈雅如7959
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有