Итак, я немного покопался, но не смог найти правильный способ сделать это.
У меня есть несколько продуктов на 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 );
}
В 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, пока формат …
…Вы можете заказать по телефону 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';
Других решений пока нет …