php - 使用 PHP 从网站或文本文档中提取数据并保存在数据库中

标签 php mysql extract

我正在构建一个地理位置应用程序。我有一个街道名称及其列表 我在以下网站上找到的坐标 streets 。这份 list 由 4000 多个街道名称和坐标组成。我正在尝试添加 列出到我的数据库中。谁能告诉我如何提取这些数据 从网站或文本文档并将其插入我的数据库 最好使用 PHP 的表。

数据库表示例

<小时/>
TABLE `street_names` (
  `id` int(11) NOT NULL,
  `name` varchar(150) DEFAULT NULL,
  `latitude` varchar(255) DEFAULT NULL,
  `longitude` varchar(255) DEFAULT NULL,
  `created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `updated_at` timestamp NULL DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

文本文档示例

<小时/>
A Kriel Street         -25.69664263     28.41030434
Abraham Mogopodi Avenue         -25.71338241     28.37033247
Absalome Street         -25.70997386     28.3568847
Alan Paton Street         -25.72122505     28.42021664
Alfred Nzo Crescent         -25.6882444     28.41519928
Annah Mabusela Street         -25.70656941     28.34339845
Anton Lembede Street         -25.71813448     28.41874969
Aphane Nhlapo Street         -25.7208474     28.38598257
Apple Close         -25.71151327     28.38914898
Areyeng Street         -25.72404151     28.38545561
Aseletho Street         -25.71910848     28.41628606
Azikwelwa Street         -25.70616386     28.40821879
Azondo Street         -25.69615534     28.41117811
B Z Ndlazi Street         -25.71074853     28.37073878
Badanile Avenue         -25.71883255     28.42320088
Bahula Street         -25.70728106     28.35488834
Baloyi Close         -25.72553726     28.38641741
Bana Street         -25.70942133     28.40631067
Banana Close         -25.71194649     28.39090203

最佳答案

我认为这个正则表达式可以实现你想要的。这还假设数据格式是一致的并且是纯文本。

(?m)^(?P<Street>(?:[A-Za-z\d]+\h)+)\h{2,}(?P<LAT>-?\d*\.\d+)\h{2,}(?P<LON>-?\d*\.\d+)$

https://regex101.com/r/ctUp0L/1/

数据点似乎被至少 2 个空格分隔,因此我使用它作为分隔符。这也可以通过 explodepreg_split 来完成。

$lines = explode(PHP_EOL, $string);
foreach($lines as $line) {
    $lines_array[] = preg_split('/\h{2,}/', $line, -1, PREG_SPLIT_NO_EMPTY);
}

https://3v4l.org/DaunT

关于php - 使用 PHP 从网站或文本文档中提取数据并保存在数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50705364/

相关文章:

php - 无法让 php 设置 session

php - Valum php AJAX 上传 : Store File Name and Path into mySQL database

php - 哪种技术堆栈可以最轻松地部署客户托管的 Web 应用程序?

php - 如何识别用户更新后的时间?

python - 从网页中提取元关键字?

php - 如何在下一个查询中使用选择选项值作为 PHP 变量?

php - 模仿Facebook "closest friend"通知行为

Mysql 选择字段中的值

javascript - 从属性值中提取数字

php 从日期中提取年/月/日/时/分/秒