我已经制作了一些缩短名称的代码,如果它超过了这么多的字符(缩短了首字母的名字,删除了middles的名字,如果姓氏总是太长则缩短直到适合)。
我有这个版本的工作(在我当前的代码之后发布)但现在我尝试了一些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,但我没有看到任何错误,除非你在某些情况下不能放置在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循环有关,但不知道是什么。
非常感谢任何帮助,谢谢。
答案 0 :(得分:1)
除了功能之外,您的代码中充斥着语法错误和不必要的括号。试试这个:
$name = "billy bobby sharkingflardo herdaderpingtonning";
while (strlen($name) > 17) { // removed extra parentheses around strlen()
$nameEx = explode(' ', $name);
if (strlen($nameEx[0] > 1)) { // removed extra and fixed unclosed parentheses
$nameEx[0] = substr($nameEx[0], 0, -(strlen($nameEx[0]) - 1));
}
while (count($nameEx) > 2) { // removed extra and fixed unclosed parentheses
unset($nameEx[1]);
}
if (strlen($nameEx[1] > 15)) { // removed extra and fixed unclosed parentheses
substr($nameEx[1], 0, -1);
}
$name = implode(' ', $nameEx);
}
echo $Name; // added missing semicolon