ホームページ >バックエンド開発 >PHPチュートリアル >PHP が数百万のデータを迅速に並べ替える方法の詳細な説明

PHP が数百万のデータを迅速に並べ替える方法の詳細な説明

*文
*文オリジナル
2018-01-05 18:03:292705ブラウズ

私は日常の仕事で、サイト内の手紙、携帯電話のテキスト メッセージ、電子メールを通じて Web サイトのメンバーにグループ メッセージを送信する通知を受け取ることがよくありますが、通常、ユーザー リストは他の同僚によって提供されるため、必然的に重複が生じます。繰り返しの送信を避けるため、情報を送信する前に、提供されたユーザーリストを重複排除する必要があります。次に、uid リストを使用して、php 配列を使用して重複を排除する方法について説明します。お役に立てれば幸いです。

100 万行を超える uid リストを取得した場合、その形式は次のようになります:

10001000 
10001001 
10001002 
...... 
10001000 
...... 
10001111  

実際、PHP 配列の特性を利用すると、重複を簡単に並べ替えることができます。 PHP 配列の定義: PHP の配列は実際には順序付けされたマップです。マップはキーに値を関連付けるタイプです。この型はさまざまな方法で最適化されているため、実数の配列、リスト (ベクトル)、ハッシュ テーブル (マップの実装)、ディクショナリ、セット、スタック、キューなどとして扱うことができます。さらなる可能性を。配列要素の値を別の配列にすることもできます。ツリー構造と多次元配列も許可されます。
PHP 配列では、キーはインデックスとも呼ばれ、一意です。この機能を使用して重複を並べ替えることができます。サンプル コードは次のとおりです。ソートされたデータは重複排除されており、効率も良く、非常に実用的です。携帯電話番号と電子メールもこの方法で重複を排除できます。

また、この方法は 2 つの uid リスト ファイルがある場合、その形式は次のとおりです。

<?php
//定义一个数组,用于存放排重后的结果 
$result = array(); 
//读取uid列表文件 
$fp = fopen(&#39;test.txt&#39;, &#39;r&#39;); 
while(!feof($fp)) 
{ 
$uid = fgets($fp); 
$uid = trim($uid); 
$uid = trim($uid, "\r"); 
$uid = trim($uid, "\n"); 
if($uid == &#39;&#39;) 
{ 
continue; 
} 
//以uid为key去看该值是否存在 
if(empty($result[$uid])) 
{ 
$result[$uid] = 1; 
} 
} 
fclose($fp); 
//将结果保存到文件 
$content = &#39;&#39;; 
foreach($result as $k => $v) 
{ 
$content .= $k."\n"; 
} 
$fp = fopen(&#39;result.txt&#39;, &#39;w&#39;); 
fwrite($fp, $content); 
fclose($fp); 
?>  

よく考えてください。配列のこの機能を使用することで、私たちの仕事においてさらに多くの問題が解決できることを見つけるのは困難です。

以上がPHP が数百万のデータを迅速に並べ替える方法の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。