我制作了一些代码,如果名称超过了这么多字符(缩短名字的首字母,删除中间名,如果姓氏整体太长,则缩短直到适合)。
我有这个工作的版本(在我当前的代码之后发布),但现在我用一些 while 循环尝试它,它抱怨循环中的第一个 if 出现意外 { (第 9 行)。
当前代码:
<?php
$name = "billy bobby sharkingflardo herdaderpingtonning";
while ((strlen($name))>17)
{
$nameEx = explode(" ",$name);
if ((strlen($nameEx[0])>1)
{
$nameEx[0] = substr($nameEx[0], 0, -(strlen($nameEx[0])-1));
}
while ((count($nameEx))>2)
{
unset($nameEx[1]);
}
if ((strlen($nameEx[1]>15))
{
substr($nameEx[1], 0, -1);
}
$name = implode(" ",$nameEx);
}
echo $Name
?>
我对 PHP 还是很陌生,但我认为这没有什么问题,除非在某些情况下不能将 if 放置在 while 循环中,但是通过一些研究,我没有发现这种情况。
我正在运行的旧代码如下:
<?php
$conn = mysql_connect('localhost', 'root', '');
mysql_select_db('amazondb', $conn);
$result = mysql_query("SELECT * FROM imported_orders");
while($row = mysql_fetch_array ($result))
{
$nL = strlen($row['RecipientName']);
echo "<br><b>Name:</b> ".$row['RecipientName']."<br>";
echo "<b>Names Length:</b> ".$nL."<br>";
if ($nL>17)
{
$nameEx = explode(" ",$row['RecipientName']);
if ((count($nameEx))>2)
{
unset($nameEx[1]);
$nameEx[0] = substr($nameEx[0], 0, -(strlen($nameEx[0])-1));
}
$name = implode(" ",$nameEx);
echo "<b>New Name:</b> ".$name."<br>";
echo "<b>New Length:</b> ".strlen($name)."<br>";
}
}
?>
这段代码适用于我的 sql 数据库,但它没有考虑多个中间名,如果姓氏本身太长。
我确定它一定与while循环有关,但不知道是什么。
非常感谢任何帮助,谢谢。