0

我正在我的网站上提取数据,我想更改我真正想要的文本。我将网站链接存储在 MYSQL 数据库中,我可以在其中以 PHP 输出链接,并且我正在使用 PHP DOM 来提取数据。我使用以下代码提取了我得到“大学橄榄球”德克萨斯理工大学的德克萨斯基督教“LIVE”的文本:

<?php
  define('DB_HOST', 'localhost');
  define('DB_USER', 'myusername');
  define('DB_PASSWORD', 'mypassword');
  define('DB_DATABASE', 'mydbname');

  $errmsg_arr = array();
  $errflag = false;
  $link = mysql_connect(DB_HOST, DB_USER, DB_PASSWORD);

  if(!$link) 
  {
    die('Failed to connect to server: ' . mysql_error());
  }

  $db = mysql_select_db(DB_DATABASE);
  if(!$db) 
  {
    die("Unable to select database");
  }

  function clean($var)
  {
    return mysql_real_escape_string(strip_tags($var));
  }
  $channels = clean($_GET['channels']);
  $id = clean($_GET['id']);

  if($errflag) 
  {
    $_SESSION['ERRMSG_ARR'] = $errmsg_arr;
    echo implode('<br />',$errmsg_arr);
  }
  else 
  {
    $insert = array();

    if(isset($_GET['channels'])) 
    {
      $insert[] = 'channels = \'' . clean($_GET['channels']) .'\'';
    }
    if(isset($_GET['id'])) 
    {
      $insert[] = 'id = \'' . clean($_GET['id']) . '\'';
    }


    if($channels && $id) 
    {
      $qrytable1="SELECT id, channels, links FROM tvguide WHERE channels='$channels' && id='$id'";
      $result1=mysql_query($qrytable1) or die('Error:<br />' . $qry . '<br />' . mysql_error());

      while ($row = mysql_fetch_array($result1))
      {
        $links = $row['links'];
        include ('simple_html_dom.php');
        $html = file_get_html($links);
        $title1 = $html->find('a[id=rowTitle1]', 0); // with this
        echo $html->find('li[id=row1-3]', 0)->plaintext;
        echo "<BR></BR>";
      }
      mysql_close($link);
    }
  }
?>

这是我提取后的 HTML 源代码:

                        7:30 PM                              College Football                                              "Texas Christian at Texas Tech"                                                                                LIVE                          <BR></BR>

我可以在 HTML 源代码中看到有很长的空间我想摆脱它,我也想忽略包括 AM 和 PM 在内的时间。

我想从这里更改 HTML 源代码:

                        7:30 PM                              College Football                                              "Texas Christian at Texas Tech"                                                                                LIVE                          <BR></BR>

对此:

<span id='title1'>College Football: Texas Christian at Texas Tech - LIVE</span><br></br>

您能告诉我如何使用当前代码更改我想要的文本吗?

4

1 回答 1

1

做这个 :

$test ='                        7:30 PM                              College Football                                              LIVE                          <BR></BR>';
//remove time hh:mm
$output = preg_replace('/\d:\d+/', '', $test);
$output = '<span id="title1">'.str_replace(array("\t", '   ', '<BR>','</BR>', 'AM','PM'), '', $output).'</span><br><br>';
$output = str_replace(' LIVE', '- LIVE', $output);

echo $output;

大学橄榄球“德克萨斯理工大学的德克萨斯基督徒” - 现场直播

它不仅在视觉上“干净”,而且在生成的 HTML 中也“干净”(但空白对读者来说并不重要,只是为了美化- 事实上,读者应该忽略空白)

<span id="title1"> College Football "Texas Christian at Texas Tech" - LIVE  </span><br><br>
于 2013-09-12T23:14:03.180 回答