Если отрицательное значение выведите «0» вместо

У меня есть простой PHP-скрипт для преобразования файла CSV в другой макет, который работает нормально, но я хочу добавить правило, которое, если значение является отрицательным, выводит 0 вместо.
Может ли кто-нибудь указать мне правильное направление на то, как это сделать (код ниже со строкой, где должно применяться правило, отмеченное)

Спасибо

<?php

function twoDecs($num_in)
{
$split = explode('.', $num_in);
if(!isset($split[1]))
$num_out = $num_in . '.00';
else{
if(strlen($split[1])<2)
$num_out = $split[0] . '.' . $split[1] . '0';
else
$num_out = $split[0] . '.' . $split[1];
}

return $num_out;
}

function array_to_csv($array_in)
{
$csv_content = 'sku;qty;special_price;price;is_in_stock
';
$lines = explode('
', $array_in);

for($i=0;$i<count($lines);$i++)
{
$line = explode(',', $lines[$i]);
if(trim($line[1])!='')
{
$csv_content .= trim($line[1]) . ';';
$csv_content .= trim($line[8]) . ';';  <----- line where rule to be added
$csv_content .= twoDecs(trim($line[6])) . ';';
$csv_content .= twoDecs(trim($line[7])) . ';';
$csv_content .= '1' . '
';
}
unset($line);
}

$now = date('YmdHis');
file_put_contents('files/ProductUpdateRF.csv', $csv_content);
echo '<a href="files/ProductUpdateRF.csv"> Download reformatted CSV here. </a>';
}
?>

0

Решение

Проверять:

$csv_content .= (intval(trim($line[8])) < 0 ? "0" : trim($line[8])) . ';';

Это использует троичный оператор что является сокращением if(),

2

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

Ну вот:

$csv_content .= max(trim($line[8]), 0).';';

Это использует Максимум который возвращает самое высокое значение. В этом случае, если значение первого параметра меньше нуля (2-й параметр), MAX вернет ноль

1

Чтобы сохранить читабельность кода и решить вашу проблему, вы можете использовать троичный (сокращенный) оператор?:

$csv_content .= (float) $line[8] < 0 ? 0 : trim($line[8]) . ';';
0

if ($line[8]<0)
$csv_content .= 0 ';';
else
$csv_content .= trim($line[8]) . ';';
-1
По вопросам рекламы [email protected]