0

所以我有数以千计的 Wordpress 帖子,其中包含我想要删除的宽度和高度属性。例如:

img class="aligncenter size-full wp-image-21011999" title="sometitle" 
alt="somealt" src="http://mysite.com/blabla/somefile.jpg" width="xxx" height="xxx"

正如我提到的,我想删除width="xxx" height="xxx"并且我想直接从 MySQL 中删除它们,不想使用任何 PHP 函数或类似函数。

有没有可以通过 PhpMyadmin 运行的查询?

是否有任何正则表达式可以用于每个帖子不同的 xxx。

谢谢!

4

2 回答 2

1

您可以编写一个小的 PHP 脚本(当然在 WordPress 之外),它可以使用 Regex 轻松完成此任务。

<?php

$host = "hostname";
$user = "username";
$pass = "password";
$db   = "database";

mysql_connect($host, $user, $pass);
mysql_select_db($db);

$pattern = "/width|height=\"[0-9]*\"/";

$query = "SELECT ID, post_content FROM wp_posts";
while ($row = mysql_fetch_assoc($query)) {
    if (preg_match($pattern, $row['post_content']))
    {
        $row['post_content'] = preg_replace($pattern, "", $row['post_content']);
        mysql_query("UPDATE wp_posts SET post_content=" . $row['post_content'] . "WHERE ID=" . $row['ID'];
    }
}

?>

无论如何我都会这样做。我假设当您说“没有 PHP 函数”时,您的意思是您希望数据库中的数据永久更新,而不是每次加载页面时都即时更新。这应该可以解决问题。编写一个原始 SQL 查询来处理这个问题可能要复杂得多。

您不需要在 WordPress 中执行此操作。您甚至可以在不同的主机上运行它,前提是该主机具有数据库访问权限。

注意:我没有测试过这些。如果您使用它,我会确保在您的数据库的一小部分上运行它,然后再将其应用到整个站点。

于 2013-01-16T22:59:50.217 回答
0

我已经使用了这个脚本,它有一些错误。我已经纠正并使用了它。有用。确保表名 (wpfs_posts) 对应于您的表名和帖子。总是有备份。

<?php

$host = "localhost";
$user = "nameuser";
$pass = "password";
$db   = "namedb";

mysql_connect($host, $user, $pass);
mysql_select_db($db);

$pattern = "/width|height=\"[0-9]*\"/";

$query = "SELECT ID, post_content FROM wpfs_posts";
$result = mysql_query($query);
while ($row = mysql_fetch_assoc($result)) {
    if (preg_match($pattern, $row['post_content']))
    {
        $row['post_content'] = preg_replace($pattern, "", $row['post_content']);
        $row['post_content']=mysql_real_escape_string($row['post_content']);
        mysql_query("UPDATE wpfs_posts SET post_content='" . $row['post_content'] . "' WHERE ID=" . $row['ID']);
    }
}

?>
于 2018-03-19T22:05:25.953 回答