
本文介绍了如何使用 PHP 从 URL 直接读取在线 Excel 文件,无需先下载到本地。通过使用 cURL 库,我们可以模拟浏览器请求,获取 Excel 文件内容,并使用 PHPSpreadsheet 库解析和处理数据。文章提供了详细的代码示例和注意事项,帮助开发者轻松实现该功能。
首先,我们需要使用 PHP 的 cURL 库来下载 Excel 文件。cURL 是一个强大的工具,可以用来发送 HTTP 请求,获取服务器的响应。以下是一个使用 cURL 下载 Excel 文件的示例代码:
<?php
function dfCurl($url) {
$ch = curl_init($url);
$dir = '../';
$fileName = basename($url);
$saveFilePath = $dir . $fileName;
$fp = fopen($saveFilePath, 'wb');
$headers = [
'authority: www.idx.co.id',
'method: GET',
'scheme: https',
'accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
'cache-control: no-cache',
'pragma: no-cache',
'user-agent: Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/95.0.4638.54 Mobile Safari/537.36',
'Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
];
curl_setopt($ch, CURLOPT_FILE, $fp);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
curl_exec($ch);
curl_close($ch);
fclose($fp);
}
// 示例 URL
$url = 'https://www.idx.co.id/Portals/0/StaticData/ListedCompanies/Corporate_Actions/New_Info_JSX/Jenis_Informasi/01_Laporan_Keuangan/02_Soft_Copy_Laporan_Keuangan//Laporan%20Keuangan%20Tahun%202021/TW1/AALI/FinancialStatement-2021-I-AALI.xlsx';
dfCurl($url);
?>代码解释:
注意事项:
立即学习“PHP免费学习笔记(深入)”;
下载 Excel 文件后,我们可以使用 PHPSpreadsheet 库来读取和处理文件中的数据。PHPSpreadsheet 是一个强大的 PHP 库,可以用来创建、读取和修改各种电子表格文件,包括 Excel 文件。
安装 PHPSpreadsheet:
可以使用 Composer 来安装 PHPSpreadsheet:
composer require phpoffice/phpspreadsheet
读取 Excel 文件的示例代码:
<?php
require 'vendor/autoload.php'; // 引入 Composer 自动加载器
use PhpOffice\PhpSpreadsheet\IOFactory;
// 文件路径
$filePath = '../FinancialStatement-2021-I-AALI.xlsx'; // 替换为实际的文件路径
try {
// 使用 IOFactory 加载电子表格
$spreadsheet = IOFactory::load($filePath);
// 获取活动的工作表
$worksheet = $spreadsheet->getActiveSheet();
// 获取最高行和列索引
$highestRow = $worksheet->getHighestRow();
$highestColumn = $worksheet->getHighestColumn();
// 循环遍历每一行
for ($row = 1; $row <= $highestRow; ++$row) {
// 循环遍历每一列
for ($col = 'A'; $col <= $highestColumn; ++$col) {
// 获取单元格的值
$cellValue = $worksheet->getCell($col . $row)->getValue();
// 输出单元格的值
echo $cellValue . "\t";
}
echo "\n";
}
} catch (\PhpOffice\PhpSpreadsheet\Reader\Exception $e) {
die('Error loading file: ' . $e->getMessage());
}
?>代码解释:
注意事项:
立即学习“PHP免费学习笔记(深入)”;
本文介绍了如何使用 PHP 从 URL 直接读取在线 Excel 文件,无需先下载到本地。通过使用 cURL 库下载 Excel 文件,并使用 PHPSpreadsheet 库解析和处理数据,可以轻松实现该功能。在实际应用中,需要根据目标网站的要求调整 HTTP 请求头,并根据需要修改代码以处理不同的数据类型和格式。
以上就是使用 PHP 无需下载直接读取在线 Excel 文件的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号