如果你不想使用正则表达式,这是解决方案之一。
<?php
$movie[0]='Amber';
$movie[1]='babar';
$movie[2]='Aviator';
$movie[3]='Caty boy';
function startsWith($haystack, $needle)
{
return !strncmp($haystack, $needle, strlen($needle));
}
foreach (range('a', 'z') as $i){
echo '<h1>'.strtoupper($i).'</h1>';
foreach($movie as $key){
if(startsWith(strtolower($key),$i)){
echo '<li>'.$key.'</li>';
}
}
}
?>
输出上面将是:
A
Amber
Aviator
B
Babar
C
Caty boy
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
Y
Z
填充当然从与数据库的$电影阵列ORDER BY SQL查询。然后$电影阵列可以在这种格式
Title - (Year)
这不会有什么区别后,放在标题 - 年或任何其他细节之后。条件是你的字符串应该以标题开头。所以即使你错过了格式,例如:
$movie[0]='Titanic';
$movie[1]='Hulk (2009)';
仍然该函数应该按照你在问题描述中描述的方式对它进行排序。希望能帮助到你。
你有什么尝试/什么是你的PHP级别(有没有线索,初学者,中级等)? – rlatief 2013-02-17 06:15:11
http://www.php.net/manual/en/book.pdo.php – Jon 2013-02-17 06:15:14
MySQLi最初可能会更简单。然后是PDO。 – Achrome 2013-02-17 06:19:11