abdalasif / geo-timezone
PHP 库,用于根据特定位置和日期计算时区。
dev-master
2024-09-03 10:06 UTC
Requires
- php: >=7.0 || >=8.0
- ext-dom: >=7.0 || >=8.0
- ext-mbstring: >=7.0 || >=8.0
- ext-xml: >=7.0 || >=8.0
- ext-zip: *
- phayes/geophp: 1.2.*
Requires (Dev)
- guzzlehttp/guzzle: 7.8
- phpunit/phpunit: 10.5
This package is auto-updated.
Last update: 2024-09-03 10:09:03 UTC
README
基于node-geo-tz包,此PHP库根据坐标(纬度、经度)和时间戳参考计算特定位置的时区。因此,此库还可以提供任何时刻特定位置的本地日期。此外,它基于由timezone-boundary-builder工具提取的时区边界,因此必须始终使用此包的最新版本。为了通过边界提高时区搜索,node-geo-tz建议创建一个基于将地球分割成四分之一和子四分之一的目录树。这个树在参考库中称为"data.zip"。
要求
运行库需要GEOS PHP扩展。因此,您应该运行脚本bin/compile-geos .sh来下载和编译它;然后,名为"geos.so"的库将被添加到/usr/lib/php中。如您所见,此脚本包含安装一些在安装过程的下一步中必要的PHP扩展。
一旦您已编译了GEOS PHP扩展,您应该创建geos.ini文件以启用模块并相应地提高性能。
最后,您应该运行composer文件,以便安装其余必要的库。
使用方法
有两个主要类
- UpdaterData:下载时区边界数据最新版本的脚本,并创建目录树(data.zip)。这可能需要几个小时,所以您可以使用来自node-geo-tz的"data.zip"进行首次测试。否则,您可以通过运行UpdaterData脚本来获取最新版本并创建目录树。目标文件夹必须具有写入权限
use GeoTimeZone\UpdaterData; $updater = new UpdaterData("/path/to/data/"); $updater->updateData();
- Calculator:提供与特定纬度、经度和时间戳相关联的时区名称或本地日期。
use GeoTimeZone\Calculator; $latitude = 39.452800; $longitude = -0.347038; $timestamp = 1469387760; $calculator = new Calculator("/path/to/data/"); // Local date $localDate = $calculator->getLocalDate($latitude, $longitude, $timestamp); /* DateTime Object ( [date] => 2016-07-24 21:16:00.000000 [timezone_type] => 3 [timezone] => Europe/Madrid ) */ // TimeZone name $timeZoneName = $calculator->getTimeZoneName($latitude, $longitude); //Europe/Madrid