PHP没有ArrayList,只有array和ArrayObject;导出数组需依需求选文本格式(CSV/JSON/serialize/var_export),注意编码、安全与内存限制。

PHP 里没有 ArrayList 这个原生类型——这是 Java 的类。你在 PHP 中实际面对的,是普通数组(array)或对象(比如 ArrayObject),而“导出为文本存盘”的需求,本质是把 PHP 数组序列化成可读、可存储的格式。
PHP 没有 ArrayList,只有 array 和 ArrayObject
直接调用 new ArrayList() 会报错:Fatal error: Class 'ArrayList' not found。PHP 的标准数组就是动态、可变长、支持混合键值的 array;如果需要类似 Java ArrayList 的接口(如 add()、get()),可用 ArrayObject 或封装一层:
$list = new ArrayObject();
$list->append('apple');
$list->append('banana');
// 转回普通数组以便后续处理:$arr = $list->getArrayCopy();
绝大多数场景下,直接用 array 更轻量、更符合 PHP 习惯。
把数组导出为纯文本(如 CSV 或行式文本)
适合简单结构(一维或二维关联/索引数组),人类可读,方便用 Excel 或记事本打开:
立即学习“PHP免费学习笔记(深入)”;
- 一维数组 → 每行一个值:
file_put_contents('data.txt', implode("\n", $arr)); - 二维索引数组(表格型)→ 用
fputcsv()写 CSV:$fp = fopen('data.csv', 'w'); foreach ($data as $row) { fputcsv($fp, $row, ',', '"'); // 自动转义、加引号 } fclose($fp); - 含中文或特殊字符时,务必在 CSV 开头写 BOM(
\xEF\xBB\xBF)避免乱码,或统一用 UTF-8 编码保存
把数组导出为结构化文本(JSON / serialize / var_export)
保留嵌套、类型、键名,适合程序间交换或调试时查看全貌:
-
json_encode($arr, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT):最常用,跨语言兼容好,但会丢掉资源、闭包、私有属性 -
serialize($arr):PHP 原生格式,能保留完整类型(包括对象),但不可读、不跨语言,且反序列化有安全风险(别从不可信源unserialize()) -
var_export($arr, true):输出合法 PHP 代码,复制粘贴就能当变量用,适合配置快照或测试数据固化
写入文件示例:file_put_contents('data.json', json_encode($arr, JSON_UNESCAPED_UNICODE));
容易被忽略的细节
导出前没检查数据是否含非 UTF-8 字符(尤其从数据库或旧系统来),会导致 json_encode() 返回 false;没设置 default_charset 或文件打开模式(如 CSV 忘了 b 标志在 Windows 下可能换行异常);还有——导出大数组时,memory_limit 不够会直接中断,这时得用流式写入(逐行 fwrite,而非一次性 json_encode 全量)。











