首页 后端开发 php教程 如何使用PHP创建CSV文件?(代码示例)

如何使用PHP创建CSV文件?(代码示例)

Feb 16, 2019 pm 04:32 PM
php

CSV(逗号分隔值)是在应用程序之间传输表格数据的最常用方法之一;创建将数据导出到CSV的代码在许多应用程序中非常有用。下面本篇文章就来带大家了解如何使用PHP创建CSV文件,希望对大家有所帮助。

如何使用PHP创建CSV文件?(代码示例)

下面就通过代码示例来具体介绍一下:

使用静态数据创建CSV文件

如果要将数据存储到csv文件中,则可以使用与以下类似的代码:

<?php
// 创建并打开“demosaved.csv”文件进行写入
$file = fopen(&#39;demosaved.csv&#39;, &#39;w&#39;);
 
// 保存列标题
fputcsv($file, array(&#39;Column 1&#39;, &#39;Column 2&#39;, &#39;Column 3&#39;, &#39;Column 4&#39;, &#39;Column 5&#39;));
 
// 样本数据,这可以从MySQL中获取
$data = array(
array(&#39;Data 11&#39;, &#39;Data 12&#39;, &#39;Data 13&#39;, &#39;Data 14&#39;, &#39;Data 15&#39;),
array(&#39;Data 21&#39;, &#39;Data 22&#39;, &#39;Data 23&#39;, &#39;Data 24&#39;, &#39;Data 25&#39;),
array(&#39;Data 31&#39;, &#39;Data 32&#39;, &#39;Data 33&#39;, &#39;Data 34&#39;, &#39;Data 35&#39;),
array(&#39;Data 41&#39;, &#39;Data 42&#39;, &#39;Data 43&#39;, &#39;Data 44&#39;, &#39;Data 45&#39;),
array(&#39;Data 51&#39;, &#39;Data 52&#39;, &#39;Data 53&#39;, &#39;Data 54&#39;, &#39;Data 55&#39;)
);
 
// 保存每一行数据
foreach ($data as $row)
{
fputcsv($file, $row);
}
 
// 关闭文件
fclose($file);
?>

代码说明

第3行:打开文件,文件名为“demosaved.csv”,用于书写。确保服务器可以写入保存此文件的位置

第6行:添加列标题。如果不想要任何列标题,可以跳过此步骤。

第9-15行:表示要存储在文件中的数据。如果你想从mysql中获取数据,你必须用代码来连接数据库并获取数据,进而替换这些行来

第17-21行:遍历每行数据并保存数据

第24行:关闭文件。在我们完成将所有数据写入文件后,需要把文件关闭。

从mysql获取数据来创建并自动下载CSV文件

<?php
// 设置输出标头,以便下载文件
header(&#39;Content-type: text/csv&#39;);
header(&#39;Content-Disposition: attachment; filename="demo.csv"&#39;);
 
// 不缓存文件
header(&#39;Pragma: no-cache&#39;);
header(&#39;Expires: 0&#39;);
 
// 创建连接到输出流的文件指针
$file = fopen(&#39;php://output&#39;, &#39;w&#39;);
 
// 打开数据库连接
$link = mysqli_connect(&#39;localhost&#39;, &#39;my_user&#39;, &#39;my_password&#39;, &#39;my_db&#39;);
 
//查询数据库
$query = &#39;SELECT field1, field2, field3, field4, field5 FROM table&#39;;
 
if ($rows = mysqli_query($link, $query))
{
// 保存每一行数据
while ($row = mysqli_fetch_assoc($rows))
{
fputcsv($file, $row);
}
//自由结果集
mysqli_free_result($result);
}
// 关闭连接
mysqli_close($link);
?>

代码说明:

因为我们要下载文件,所以我们必须发送一些头文件(第3行和第4行),告诉浏览器下载该文件。

第3行:告诉浏览器内容的MIME类型是text / csv,因为我们要发送一个csv文件

第4行:发送标头“Content-Disposition”,其值为“attachment”,文件名为“demo.csv”。这将告诉浏览器下载名为“demo.csv”的文件,而不是显示它。

第7行和第8行:告诉浏览器不要缓存文件。如果我们发送多个同名文件,这很有用,否则这不是必需的

第11行:表示打开文件指针以发送数据

第14行~第30行:从mysql获取数据

注:需要确保更改数据库的连接参数和查询。此外,该数据库相关代码仅是一个示例。在实际应用程序中,它可能位于不同的文件中,并且还应该有错误处理。

以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注php中文网相关教程栏目!!!

以上是如何使用PHP创建CSV文件?(代码示例)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1605
29
PHP教程
1510
276
超越灯堆:PHP在现代企业体系结构中的作用 超越灯堆:PHP在现代企业体系结构中的作用 Jul 27, 2025 am 04:31 AM

PHPisstillrelevantinmodernenterpriseenvironments.1.ModernPHP(7.xand8.x)offersperformancegains,stricttyping,JITcompilation,andmodernsyntax,makingitsuitableforlarge-scaleapplications.2.PHPintegrateseffectivelyinhybridarchitectures,servingasanAPIgateway

PHP中的对象关联映射(ORM)性能调整 PHP中的对象关联映射(ORM)性能调整 Jul 29, 2025 am 05:00 AM

避免N 1查询问题,通过提前加载关联数据来减少数据库查询次数;2.仅选择所需字段,避免加载完整实体以节省内存和带宽;3.合理使用缓存策略,如Doctrine的二级缓存或Redis缓存高频查询结果;4.优化实体生命周期,定期调用clear()释放内存以防止内存溢出;5.确保数据库索引存在并分析生成的SQL语句以避免低效查询;6.在无需跟踪变更的场景下禁用自动变更跟踪,改用数组或轻量模式提升性能。正确使用ORM需结合SQL监控、缓存、批量处理和适当优化,在保持开发效率的同时确保应用性能。

用PHP和RabbitMQ建造弹性微服务 用PHP和RabbitMQ建造弹性微服务 Jul 27, 2025 am 04:32 AM

要构建弹性的PHP微服务,需使用RabbitMQ实现异步通信,1.通过消息队列解耦服务,避免级联故障;2.配置持久化队列、持久化消息、发布确认和手动ACK以确保可靠性;3.使用指数退避重试、TTL和死信队列安全处理失败;4.通过supervisord等工具守护消费者进程并启用心跳机制保障服务健康;最终实现系统在故障中持续运作的能力。

VSCODE设置。JSON位置 VSCODE设置。JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位于用户级或工作区级路径,用于自定义VSCode设置。1.用户级路径:Windows为C:\Users\\AppData\Roaming\Code\User\settings.json,macOS为/Users//Library/ApplicationSupport/Code/User/settings.json,Linux为/home//.config/Code/User/settings.json;2.工作区级路径:项目根目录下的.vscode/settings

为PHP创建准备生产的Docker环境 为PHP创建准备生产的Docker环境 Jul 27, 2025 am 04:32 AM

使用正确的PHP基础镜像并配置安全、性能优化的Docker环境是实现生产就绪的关键。1.选用php:8.3-fpm-alpine作为基础镜像以减少攻击面并提升性能;2.通过自定义php.ini禁用危险函数、关闭错误显示并启用Opcache及JIT以增强安全与性能;3.使用Nginx作为反向代理,限制访问敏感文件并正确转发PHP请求至PHP-FPM;4.采用多阶段构建优化镜像,移除开发依赖,设置非root用户运行容器;5.可选Supervisord管理多个进程如cron;6.部署前验证无敏感信息泄

在PHP中构建不变的物体,并具有可读的属性 在PHP中构建不变的物体,并具有可读的属性 Jul 30, 2025 am 05:40 AM

ReadonlypropertiesinPHP8.2canonlybeassignedonceintheconstructororatdeclarationandcannotbemodifiedafterward,enforcingimmutabilityatthelanguagelevel.2.Toachievedeepimmutability,wrapmutabletypeslikearraysinArrayObjectorusecustomimmutablecollectionssucha

无服务器革命:使用BREF部署可扩展的PHP应用程序 无服务器革命:使用BREF部署可扩展的PHP应用程序 Jul 28, 2025 am 04:39 AM

Bref使PHP开发者能无需管理服务器即可构建可扩展、成本高效的应用。1.Bref通过提供优化的PHP运行时层,将PHP带入AWSLambda,支持PHP8.3等版本,并与Laravel、Symfony等框架无缝集成;2.部署步骤包括:使用Composer安装Bref,配置serverless.yml定义函数和事件,如HTTP端点和Artisan命令;3.执行serverlessdeploy命令即可完成部署,自动配置APIGateway并生成访问URL;4.针对Lambda限制,Bref提供解决

深入了解PHP的内部垃圾收集机制 深入了解PHP的内部垃圾收集机制 Jul 28, 2025 am 04:44 AM

PHP的垃圾回收机制基于引用计数,但循环引用需靠周期性运行的循环垃圾回收器处理;1.引用计数在变量无引用时立即释放内存;2.循环引用导致内存无法自动释放,需依赖GC检测并清理;3.GC在“可能根”zval达阈值或手动调用gc_collect_cycles()时触发;4.长期运行的PHP应用应监控gc_status()、适时调用gc_collect_cycles()以避免内存泄漏;5.最佳实践包括避免循环引用、使用gc_disable()优化性能关键区及通过ORM的clear()方法解引用对象,最

See all articles