如何向meta_query添加过滤器,例如仅查找Roma Numeric

问题描述 投票:0回答:2

我有一些meta_query的情境问题。客户搜索IV,但结果包括private(原始单词是私人的)。我想只显示包含IV(罗马数字)的帖子。我的meta_query从Custom插件中的Title,sub title和description中搜索。我找到了REGEXP,但是找不到从标题,子标题和描述中找到Roam数字的正确方法。

客户只能找到罗马数字,他们也可以找到任何单词等。


    $args = array(
        'numberposts' => -1,
        'category' => 0,
        'orderby' => 'post_date',
        'order' => 'DESC',
        'meta_query' => array(
            'relation' => 'OR',
            array(
                'key' => 'title',
                'value' => $search_term,
                'compare' => 'LIKE',
            ),
            array(
                'key' => 'sub-title',
                'value' => $search_term,
                'compare' => 'LIKE',
            ),
            array(
                'key' => 'description',
                'value' => $search_term,
                'compare' => 'LIKE',
            )
        ),
        'post_type' => 'gallery',
        'post_status' => 'publish',
        'suppress_filters' => true
    );

    $posts = get_posts($args, ARRAY_A); 

wordpress roman-numerals meta-query
2个回答
0
投票

正则表达式应包括如下的罗马数字(假设$search_term仅包括请求的罗马数字:

$regEx = '/(' . strtoupper($search_term) . ')/g';

0
投票

我用标题,描述和子标题使用正则表达式解决了我的问题。仍在寻找最佳答案并不是一个好主意。

$tempFlag = false;      
foreach (explode(" ", $description) as $temp) {
            if (preg_match('/^(?=[MDCLXVI])M*(C[MD]|D?C{0,3})(X[CL]|L?X{0,3})(I[XV]|V?I{0,3})$/', $temp)) {

                if (in_array($temp, $romeNumber)) {
                    $tempFlag = true;
                }
            }
        }
© www.soinside.com 2019 - 2024. All rights reserved.