Xav*_*avi 1 php country-codes mobile-country-code
我从数据库中获取手机号码我有更多的1000手机号码,我的数据库看起来像这样
mobilenumber
971525478965
919844005522
45712345678
Run Code Online (Sandbox Code Playgroud)
我想通过数据库中的每个数字,并countrycode从手机号码显示countrycode和使用PHP的国家
比如这样
countrycode 971 country UAE
countrycode 91 country India
countrycode 45 country Denmark
Run Code Online (Sandbox Code Playgroud)
任何人有任何建议请指导我如何做到这一点.
我试过这样,但想从数据库中检查多个移动数据
<?php
$number = "971527139011";
$countrys = array(
'1' => 'us',
'2' => 'uk',
'3' => 'de',
'44' => 'fi',
'123' => 'no',
'971' =>'uae',
'91' =>'india',
'92' =>'pakistan'
);
$i = 4;
$country = "";
while ($i > 0) {
if (isset($countrys[substr($number, 0, $i)])) {
$country = $countrys[substr($number, 0, $i)];
break;
} else {
$i--;
}
}
echo $country;
?>
Run Code Online (Sandbox Code Playgroud)
编辑
<?php
$dbHost = 'localhost'; // usually localhost
$dbUsername = 'root';
$dbPassword = '1234fedf';
$dbDatabase = 'smsmobile';
$db = mysql_connect($dbHost, $dbUsername, $dbPassword) or die ("Unable to connect to Database Server.");
mysql_select_db ($dbDatabase, $db) or die ("Could not select database.");
$sql = "SELECT destinationaddress FROM reporting";
//print $sql;
$queryRes1 = mysql_query($sql);
while($rows=mysql_fetch_assoc($queryRes1))
{
$destinationaddress[] = $rows['destinationaddress'];
}
$phones = $destinationaddress;
// get your list of country codes
$ccodes = array(
'1' => 'us',
'2' => 'uk',
'3' => 'de',
'44' => 'fi',
'123' => 'no',
'971' =>'uae',
'91' =>'india',
'92' =>'pakistan'
);
krsort( $ccodes );
foreach( $phones as $pn )
{
foreach( $ccodes as $key=>$value )
{
if ( substr( $pn, 0, strlen( $key ) ) == $key )
{
// match
$country[$pn] = $value;
break;
}
}
}
print_r( $country );
?>
Run Code Online (Sandbox Code Playgroud)
这样的东西会起作用:
// get your list of numbers from DB
$phones = array( '971527139011', '171527139011' );
// get your list of country codes
$ccodes = array(
'1' => 'us',
'2' => 'uk',
'3' => 'de',
'44' => 'fi',
'123' => 'no',
'971' =>'uae',
'91' =>'india',
'92' =>'pakistan'
);
krsort( $ccodes );
foreach( $phones as $pn )
{
foreach( $ccodes as $key=>$value )
{
if ( substr( $pn, 0, strlen( $key ) ) == $key )
{
// match
$country[$pn] = $value;
break;
}
}
}
print_r( $country );
Run Code Online (Sandbox Code Playgroud)
编辑
数据非常混乱,我建议你将它存储在不同的列中,但是,如果数据的结构总是相同的,这将从中提取国家/代码:
$data = array( 'country : Denmark prefix:45', 'country : Pakistan prefix:92' );
foreach ( $data as $string )
{
$_a = explode( ':', $string );
$_b = explode( ' ', $_a[1] );
$ccode[$_a[2]] = $_b[1];
}
print_r( $ccode );
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8655 次 |
| 最近记录: |