У меня есть довольно большая база данных продуктов на веб-странице. Эта веб-страница была написана на PHP, и теперь мне нужно перенести ее базу данных на сайт Wordpress (WooCommerce). Я уже понял, как добавить продукты. Я сделал PHP-файл (за пределами Wordpress) с этим заголовком, так что я могу использовать все функции WordPress:Как добавить новый пользовательский атрибут продукта в WooCommerce программно?
include('../wp/wp-load.php');
require_once('../wp/wp-admin/includes/media.php');
require_once('../wp/wp-admin/includes/file.php');
require_once('../wp/wp-admin/includes/image.php');
Во-первых, я получаю все продукты из старой базы данных в PHP массив $ элементов, а затем цикл через этот массив, используя цикл foreach. Внутри цикла у меня есть этот код:
$user_id = get_current_user();
$post_id = wp_insert_post(array(
'post_author' => $user_id,
'post_title' => $item['termek'],
'post_content' => $item['reszletes_leiras'],
'post_status' => 'publish',
'post_type' => "product",
));
wp_set_object_terms($post_id, 'simple', 'product_type');
update_post_meta($post_id, '_visibility', 'visible');
update_post_meta($post_id, '_stock_status', 'instock');
update_post_meta($post_id, 'total_sales', '0');
update_post_meta($post_id, '_downloadable', 'no');
update_post_meta($post_id, '_virtual', 'no');
update_post_meta($post_id, '_regular_price', $item['brutto_ar']);
update_post_meta($post_id, '_sale_price', $item['brutto_ar']);
update_post_meta($post_id, '_purchase_note', '');
update_post_meta($post_id, '_featured', 'no');
update_post_meta($post_id, '_weight', '');
update_post_meta($post_id, '_length', '');
update_post_meta($post_id, '_width', '');
update_post_meta($post_id, '_height', '');
update_post_meta($post_id, '_sku', $item['id']);
update_post_meta($post_id, '_product_attributes', array());
update_post_meta($post_id, '_sale_price_dates_from', '');
update_post_meta($post_id, '_sale_price_dates_to', '');
update_post_meta($post_id, '_price', '');
update_post_meta($post_id, '_sold_individually', '');
update_post_meta($post_id, '_manage_stock', 'no');
update_post_meta($post_id, '_backorders', 'no');
update_post_meta($post_id, '_stock', '');
Моя проблема заключается в том, что у меня есть массив в $ пункт [ «parameterek»], который выглядит Kile это:
["Some custom attribute"] => (string)"Something"
["Another custom attribute"] => (string)"Something else"
Теперь мне нужно добавить эти поля для продуктов как пользовательские атрибуты. Ключ массива - это имя, а значение - это ... значение, конечно. Я пытался сделать это таким образом, но этот код кажется не делать ничего:
foreach(array_keys($item['parameterek']) as $key) {
register_attribute($key);
}
wproduct_set_attributes($post_id, $item['parameterek']);
function register_attribute($name){
$paname = 'pa_' . htmlspecialchars(stripslashes($name));
$permalinks = get_option('woocommerce_permalinks');
$taxonomy_data = array(
'hierarchical' => false,
'update_count_callback' => '_update_post_term_count',
'labels' => array(
'name' => $name,
'singular_name' => $name,
'search_items' => sprintf(__('Search %s', 'woocommerce'), $label),
'all_items' => sprintf(__('All %s', 'woocommerce'), $label),
'parent_item' => sprintf(__('Parent %s', 'woocommerce'), $label),
'parent_item_colon' => sprintf(__('Parent %s:', 'woocommerce'), $label),
'edit_item' => sprintf(__('Edit %s', 'woocommerce'), $label),
'update_item' => sprintf(__('Update %s', 'woocommerce'), $label),
'add_new_item' => sprintf(__('Add New %s', 'woocommerce'), $label),
'new_item_name' => sprintf(__('New %s', 'woocommerce'), $label)
),
'show_ui' => false,
'query_var' => true,
'rewrite' => array(
'slug' => empty($permalinks['attribute_base']) ? '' : trailingslashit($permalinks['attribute_base']) . sanitize_title($name),
'with_front' => false,
'hierarchical' => true
),
'sort' => false,
'public' => true,
'show_in_nav_menus' => false,
'capabilities' => array(
'manage_terms' => 'manage_product_terms',
'edit_terms' => 'edit_product_terms',
'delete_terms' => 'delete_product_terms',
'assign_terms' => 'assign_product_terms',
)
);
register_taxonomy($paname, array('product'), $taxonomy_data);
}
function wcproduct_set_attributes($post_id, $attributes) {
$i = 0;
// Loop through the attributes array
foreach ($attributes as $name => $value) {
$product_attributes[$i] = array (
'name' => 'pa_' . htmlspecialchars(stripslashes($name)), // set attribute name
'value' => $value, // set attribute value
'position' => 1,
'is_visible' => 1,
'is_variation' => 0,
'is_taxonomy' => 1
);
$i++;
}
update_post_meta($post_id, '_product_attributes', $product_attributes);
}
Так что мой вопрос: Что это самый простой способ добавить пользовательские атрибуты продукта из массива с помощью PHP?
Спасибо за ваш ответ, это работает, но у меня есть небольшая проблема с этим. wc_clean, кажется, возвращает пустую строку, если в названии есть акцентированный chararcter. Если я удалю wc_clean из кода, он не включит ничего. Какие-либо предложения? (Теперь это выглядит на странице продукта: https://s21.postimg.org/akc7vsllz/image.png) –
wc_clean использует sanitize_text_field. Вы можете проверить здесь функцию: http://woocommerce.wp-a2z.org/oik_api/sanitize_text/ Отладка, чтобы проверить, не применяете ли вы функцию stripslash или символьного кодирования, которая предотвращает работу wc_clean. – Dez
Наконец, я могу заставить его работать с помощью wc_clean (htmlentities ($ key, 0, «ISO8859-1»)); Теперь он отлично работает, еще раз спасибо за ваш быстрый ответ! :) (Результаты: https://s10.postimg.org/v9ft0g14p/image.png) –