Пользовательская сортировка товаров, когда заголовок состоит из букв и цифр в WooCommerce

Итак, я немного покопался, но не смог найти правильный способ сделать это.

У меня есть несколько продуктов на WooCommerce (WordPress), но их название состоит из букв, смешанных с цифрами.
Мне нужно, чтобы эти продукты были напечатаны следующим образом (например):

FNC21000-С
FNC24500-С
FNC232500-С

Но, конечно же, WordPress дает мне:

FNC21000-С
FNC232500-С
FNC24500-С

Есть ли способ добиться этого?

Я думаю, что я мог бы кое-что сделать в WP_Query, но я действительно новичок в PHP, и я знаю, что некоторые из возможных исправлений в PHP, некоторые в MySQL … и тот факт, что заголовок — ОБА строка и целое число, заставляет меня чувствовать себя невежественным о том, как написать это …

У кого-нибудь есть предложения?

Ниже class-wc-query.php, который, я считаю, должен быть файлом, который мне нужно отредактировать:

/**
* Returns an array of arguments for ordering products based on the selected values.
*
* @access public
* @return array
*/
public function get_catalog_ordering_args( $orderby = '', $order = '' ) {
// Get ordering from query string unless defined
if ( ! $orderby ) {
$orderby_value = isset( $_GET['orderby'] ) ? wc_clean( $_GET['orderby'] ) : apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );

// Get order + orderby args from string
$orderby_value = explode( '-', $orderby_value );
$orderby       = esc_attr( $orderby_value[0] );
$order         = ! empty( $orderby_value[1] ) ? $orderby_value[1] : $order;
}

$orderby = strtolower( $orderby );
$order   = strtoupper( $order );
$args    = array();

// default - menu_order
$args['orderby'] = "strlen('title') => 'ASC', 'title' => 'ASC'";
//      $args['orderby']  = 'title';
$args['order']    = $order == 'DESC' ? 'DESC' : 'ASC';
$args['meta_key'] = '';

switch ( $orderby ) {
case 'rand' :
$args['orderby']  = 'rand';
break;
case 'date' :
$args['orderby']  = 'date ID';
$args['order']    = $order == 'ASC' ? 'ASC' : 'DESC';
break;
case 'price' :
$args['orderby']  = "meta_value_num ID";
$args['order']    = $order == 'DESC' ? 'DESC' : 'ASC';
$args['meta_key'] = '_price';
break;
case 'popularity' :
$args['meta_key'] = 'total_sales';

// Sorting handled later though a hook
add_filter( 'posts_clauses', array( $this, 'order_by_popularity_post_clauses' ) );
break;
case 'rating' :
// Sorting handled later though a hook
add_filter( 'posts_clauses', array( $this, 'order_by_rating_post_clauses' ) );
break;
case 'title' :
$args['orderby'] = "strlen('title') => 'ASC', 'title' => 'ASC'";
//$args['orderby']  = 'meta_value meta_value_num title';
$args['order']    = $order == 'DESC' ? 'DESC' : 'ASC';
break;
}

return apply_filters( 'woocommerce_get_catalog_ordering_args', $args );
}

1

Решение

В PHP просто позвоните natsort ().

Код: (демонстрация)

$array=['FND100000-C','FNC24500-C','FNC232500-C','FMC30000-C','FNC21000-C'];
natsort($array);
var_export($array);

Выход:

array (
3 => 'FMC30000-C',
4 => 'FNC21000-C',
1 => 'FNC24500-C',
2 => 'FNC232500-C',
0 => 'FND100000-C',
)

В MYSQL, пока формат …

  • 3 буквы тогда
  • серия чисел тогда
  • тогда дефис
  • один или несколько символов

…Вы можете заказать по телефону SUBSTRING () а также SUBSTRING_INDEX ()

Таблица & Запрос: (демонстрация)

CREATE TABLE `test` (
`PrdID` varchar(50) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1;

INSERT INTO `test` (`PrdID`) VALUES
('FMC30000-C'),
('FNC21000-B'),
('FNC21000-C'),
('FNC232500-C'),
('FNC24500-C'),
('FND100000-C');

ALTER TABLE `test`
ADD PRIMARY KEY (`PrdID`);

SELECT PrdID,
SUBSTRING(PrdID,1,3),
SUBSTRING(SUBSTRING_INDEX(PrdID,'-',1),4),
SUBSTRING_INDEX(PrdID,'-',-1)
FROM `test`
ORDER BY
SUBSTRING(PrdID,1,3),
CAST(SUBSTRING(SUBSTRING_INDEX(PrdID,'-',1),4) AS UNSIGNED),
SUBSTRING_INDEX(PrdID,'-',-1)

Выход:

PrdID       | SUBSTRING(PrdID,1,3) | SUBSTRING(SUBSTRING_INDEX(PrdID,'-',1),4) | SUBSTRING_INDEX(PrdID,'-',-1)
----------------------------------------------------------------------------------------------------------------
FMC30000-C  |         FMC          |                  30000                    |               C
FNC21000-B  |         FNC          |                  21000                    |               B
FNC21000-C  |         FNC          |                  21000                    |               C
FNC24500-C  |         FNC          |                  24500                    |               C
FNC232500-C |         FNC          |                  232500                   |               C
FND100000-C |         FND          |                  100000                   |               C

Вот выстрел в темноте от разработчика, не являющегося WordPress …

$ args [‘orderby’] = «substr (‘title’, 0,3) => ‘ASC’, substr (strstr (‘title’, ‘-‘, true), 3) => ‘ASC’, substr ( ‘title’, strpos (‘title’, ‘-‘) + 1) => ‘ASC’ «;

демонстрация

Посмотрев на:
https://github.com/woocommerce/woocommerce/blob/master/includes/class-wc-query.php похоже, что компоненты orderby разделены пробелами, а не запятыми. Попробуй это:

$args['orderby'] = "substr('title',0,3) substr(strstr('title','-',true),3) substr('title',strpos('title','-')+1)";
$args['order'] = $order==='DESC'?'DESC':'ASC';
0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector