0

我有一个包含发票详细信息的 html 文件

我想知道有没有一种方法可以只检索发票号码并使用 php 将其单独存储在我的 sql 数据库中?

<p>Invoice ID: 0201</p>
<p>MID : Q987</p>
<p>Desciption: Solid Concrete Blocks</p>
<p>Qty: 7478 Blocks </p>
<p>&nbsp;</p>
<p>Invoice ID: 0324</p>
<p>MID : Q443</p>
<p>Desciption: Window Slides with Chrome </p>
<p>Qty: 33 Units </p>
4

2 回答 2

1

您可以尝试这样的方法来提取所有发票编号:

<?php

$input = "<body> 
<p>Invoice ID: 0201</p> 
<p>MID : Q987</p> 
<p>Desciption: Solid Concrete Blocks</p> 
<p>Qty: 7478 Blocks </p> 

<p> </p> 
<p>Invoice ID: 0324</p> 
<p>MID : Q443</p> 
<p>Desciption: Window Slides with Chrome </p> 
<p>Qty: 33 Units </p> 
</body>";

$invoice_ids = array();
if(preg_match_all('{<p>Invoice ID:\s*(\d+)</p>}',$input,$matches)) {
    $invoice_ids = $matches[1];
}

var_dump($invoice_ids);

?>

输出:

array(2) {
  [0]=>
  string(4) "0201"
  [1]=>
  string(4) "0324"
}

提取所有发票编号后,您可以使用以下方法将它们插入数据库表中:

<?php
$con = mysql_connect("localhost","USRNAME","PASSWD");
if (!$con) {
    die('Could not connect: ' . mysql_error());
}

mysql_select_db("DB_NAME", $con);

foreach($invoice_ids as $id) {

    $query = "INSERT INTO YOUR_TABLE_NAME(invoice_num) VALUES $id";

    if(!mysql_query($query,$con)) {
        die('Error: ' . mysql_error());
    }

}
mysql_close($con)
?>
于 2010-03-03T09:32:00.353 回答
0

这里有几个步骤:

1:创建与您的数据匹配的数据库模式。模式是数据库表的布局。

2:使用codaddict建议的方法解析html doc并获取数据

3:一次循环遍历一条记录并使用 INSERT 将其放入表中。

如果没有更多关于此的具体信息,我们无法告诉您更多信息。

于 2010-03-03T09:35:02.563 回答