Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/281.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php Wordpress csv导入副本_Php_Mysql_Wordpress_Csv - Fatal编程技术网

Php Wordpress csv导入副本

Php Wordpress csv导入副本,php,mysql,wordpress,csv,Php,Mysql,Wordpress,Csv,我已经为wordpress使用了csv导入插件的改编版本。它导入csv以创建和更新帖子。为了更新现有的帖子,我添加了一个按标题查找帖子id的编辑,如果它存在,它将覆盖,否则它将创建一个新帖子 问题是它似乎不是很可靠!如果我多次导入同一个csv,它会覆盖大部分csv,但会得到一些副本。有没有什么方法可以让这更可靠,或者有没有其他方法可以处理重复的帖子 此处创建帖子的主要功能 function create_post($data, $options) { extract($options)

我已经为wordpress使用了csv导入插件的改编版本。它导入csv以创建和更新帖子。为了更新现有的帖子,我添加了一个按标题查找帖子id的编辑,如果它存在,它将覆盖,否则它将创建一个新帖子

问题是它似乎不是很可靠!如果我多次导入同一个csv,它会覆盖大部分csv,但会得到一些副本。有没有什么方法可以让这更可靠,或者有没有其他方法可以处理重复的帖子

此处创建帖子的主要功能

 function create_post($data, $options) {
    extract($options);
//edit 1 added here
   global $wpdb;  
//end

    $data = array_merge($this->defaults, $data);
    $type = $data['csv_post_type'] ? $data['csv_post_type'] : 'post';
    $valid_type = (function_exists('post_type_exists') &&
        post_type_exists($type)) || in_array($type, array('post', 'page'));

    if (!$valid_type) {
        $this->log['error']["type-{$type}"] = sprintf(
            'Unknown post type "%s".', $type);
    }

    $new_post = array(
        'post_title'   => convert_chars($data['csv_post_title']),
        'post_content' => wpautop(convert_chars($data['csv_post_post'])),
        'post_status'  => $opt_draft,
        'post_type'    => $type,
        'post_date'    => $this->parse_date($data['csv_post_date']),
        'post_excerpt' => convert_chars($data['csv_post_excerpt']),
        'post_name'    => $data['csv_post_slug'],
        'post_author'  => $this->get_auth_id($data['csv_post_author']),
        'tax_input'    => $this->get_taxonomies($data),
        'post_parent'  => $data['csv_post_parent'],
    );

// edit 2 here
    $new_post['ID'] = $wpdb->get_var( "SELECT ID FROM $wpdb->posts WHERE post_title = '" .   $data['csv_post_title'] . "'" );
// ends

    // pages don't have tags or categories
    if ('page' !== $type) {
        $new_post['tags_input'] = $data['csv_post_tags'];

        // Setup categories before inserting 
        $cats = $this->create_or_get_categories($data, $opt_cat);
        $new_post['post_category'] = $cats['post'];
    }

// edit 3
    if(!empty($new_post['ID'])) {
    $id = wp_update_post($new_post);
} else {
    $id = wp_insert_post($new_post);
}
// ends

    if ('page' !== $type && !$id) {
        // cleanup new categories on failure
        foreach ($cats['cleanup'] as $c) {
            wp_delete_term($c, 'category');
        }
    }
    return $id;
}

谢谢

修复!我使用了内置的wordpress函数,
get\u page\u by\u title
。下面是我用来定位正确帖子的代码

if (!get_page_by_title( $bpp_title, 'OBJECT', 'publications')) {


    $id = wp_insert_post($new_post);

    } else {

        $bpp_page = get_page_by_title( $bpp_title, 'OBJECT', 'publications');
        $new_post['ID'] = $bpp_page->ID;

        $id = wp_update_post($new_post);

    }

在我的插件CSV 2帖子中,我提到这篇文章已经被采纳了。我建议在可能的情况下比较post_name/permalink,除非您非常了解自己的数据。标题(post_标题)可以有重复的值。