다차원 배열을 정렬하는 일반적인 방법은
1입니다. 정렬된 데이터를 가져와서 $arrSort 배열에 넣습니다. 키 인덱스는 정렬할 배열의 인덱스로, 고유성을 보장합니다.
2. $arrSort가 정렬됩니다.
3 $arrSort를 탐색하여 해당 인덱스에 따라 다차원 배열의 데이터를 얻고, 정렬된 다차원 배열을 재구성합니다.
코드 복사 코드는 다음과 같습니다.
배열
(
[0] => 배열
(
[링크] => 테스트
[이름] => ; test.rpm
[유형] => 파일
[크기] => 988.9k
[mtime] => 1185160178)
....
)
오래전에 인터넷에서 찾은 정렬 기능인데 비효율적이지만 아주 실용적이네요
코드 복사 코드는 다음과 같습니다.
_array_sort($arrFile, 1, 1);//이름 필드에 따라 정렬
_array_sort( $arrFile, 3, 1);//크기에 따라 정렬 필드
/*
@records 정렬할 배열
@field 정렬할 필드, 숫자인지 주의하세요
@역순 또는 역순
*/
function _array_sort($records, $field, $reverse, $ defaultSortField = 0)
{
$uniqueSortId = 0
$hash = array();
$sortedRecords = array();
$ indexedArray = array()
foreach($ $record로 기록)
{
$uniqueSortId;
$recordStr = implode("|", $ Record)."|".$uniqueSortId;
$recordArray[] =explore("| ", $recordStr);
}
$primarySortIndex = count($record);
$records = $recordArray;
foreach($records as $record)
{
$ hash[$record[$primarySortIndex]] = $record[$field];
}
uasort($hash , "strnatcasecmp")
if($reverse)
$hash = array_reverse( $hash, true);
$valueCount = array_count_values($hash);
foreach($hash as $primaryKey => $value)
{
$indexedArray[] = $primaryKey; 🎜>}
$i = 0;
foreach($hash as $primaryKey => $value)
{
$i
if($valueCount[$value] > 1)
{
foreach($records를 $record로)
{
if($primaryKey == $record[$primarySortIndex])
{
$tempArr[$record[ $defaultSortField]."__".$i] = $record;
}
}
$index = array_search($primaryKey, $indexedArray)
if(($ i == count($records)) || ($value != $hash[$indexedArray[$index 1]]) )
{
uksort($tempArr, "strnatcasecmp")
if ($reverse)
$tempArr = array_reverse($tempArr);
foreach($tempArr as $newRecs)
{
$sortedRecords [] = $newRecs; tempArr = array()
}
}
else
{
foreach($ 레코드를 $record로 저장)
{
if($primaryKey == $record[$ PrimarySortIndex])
{
$sortedRecords[] = $record;
break;
}
}
}
}
return $sortedRecords;
II array_map 및 array_mutisor를 사용하여 정렬
array_mutisor는 여러 값을 기반으로 수행할 수도 있습니다. 2차 또는 3중 정렬은 이전 기능과 비교할 수 없습니다.
코드 복사
코드는 다음과 같습니다.
array_map 사용 정렬할 배열 가져오기$arrField = array_map(create_function('$n', 'return $ n["size"];'), $arrFile) //array_mutisort를 사용하여 정렬$array_multisort($arrField, SORT_DESC, $arrFile)
III 최종 테스트
188개의 데이터 배열로 테스트하고 50번 정렬하여 평균을 구합니다.
첫 번째 유형 방법
0.04269016 이름
0.04267142 크기
두 번째 방법
0.00083924 크기
결과는 자명하다.
위에서는 muv-luv(alternative)의 내용을 포함하여 다차원 배열 정렬을 효율적으로 처리하기 위해 php array_map array_multisort를 도입했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되길 바랍니다.

PHP는 동적 웹 개발 및 서버 측 응용 프로그램에 사용되는 서버 측 스크립팅 언어입니다. 1.PHP는 편집이 필요하지 않으며 빠른 발전에 적합한 해석 된 언어입니다. 2. PHP 코드는 HTML에 포함되어 웹 페이지를 쉽게 개발할 수 있습니다. 3. PHP는 서버 측 로직을 처리하고 HTML 출력을 생성하며 사용자 상호 작용 및 데이터 처리를 지원합니다. 4. PHP는 데이터베이스와 상호 작용하고 프로세스 양식 제출 및 서버 측 작업을 실행할 수 있습니다.

PHP는 지난 수십 년 동안 네트워크를 형성했으며 웹 개발에서 계속 중요한 역할을 할 것입니다. 1) PHP는 1994 년에 시작되었으며 MySQL과의 원활한 통합으로 인해 개발자에게 최초의 선택이되었습니다. 2) 핵심 기능에는 동적 컨텐츠 생성 및 데이터베이스와의 통합이 포함되며 웹 사이트를 실시간으로 업데이트하고 맞춤형 방식으로 표시 할 수 있습니다. 3) PHP의 광범위한 응용 및 생태계는 장기적인 영향을 미쳤지 만 버전 업데이트 및 보안 문제에 직면 해 있습니다. 4) PHP7의 출시와 같은 최근 몇 년간의 성능 향상을 통해 현대 언어와 경쟁 할 수 있습니다. 5) 앞으로 PHP는 컨테이너화 및 마이크로 서비스와 같은 새로운 도전을 다루어야하지만 유연성과 활발한 커뮤니티로 인해 적응력이 있습니다.

PHP의 핵심 이점에는 학습 용이성, 강력한 웹 개발 지원, 풍부한 라이브러리 및 프레임 워크, 고성능 및 확장 성, 크로스 플랫폼 호환성 및 비용 효율성이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 웹 서버와 우수한 통합 및 여러 데이터베이스를 지원합니다. 3) Laravel과 같은 강력한 프레임 워크가 있습니다. 4) 최적화를 통해 고성능을 달성 할 수 있습니다. 5) 여러 운영 체제 지원; 6) 개발 비용을 줄이기위한 오픈 소스.

PHP는 죽지 않았습니다. 1) PHP 커뮤니티는 성능 및 보안 문제를 적극적으로 해결하고 PHP7.x는 성능을 향상시킵니다. 2) PHP는 최신 웹 개발에 적합하며 대규모 웹 사이트에서 널리 사용됩니다. 3) PHP는 배우기 쉽고 서버가 잘 수행되지만 유형 시스템은 정적 언어만큼 엄격하지 않습니다. 4) PHP는 컨텐츠 관리 및 전자 상거래 분야에서 여전히 중요하며 생태계는 계속 발전하고 있습니다. 5) Opcache 및 APC를 통해 성능을 최적화하고 OOP 및 설계 패턴을 사용하여 코드 품질을 향상시킵니다.

PHP와 Python에는 고유 한 장점과 단점이 있으며 선택은 프로젝트 요구 사항에 따라 다릅니다. 1) PHP는 웹 개발, 배우기 쉽고 풍부한 커뮤니티 리소스에 적합하지만 구문은 현대적이지 않으며 성능과 보안에주의를 기울여야합니다. 2) Python은 간결한 구문과 배우기 쉬운 데이터 과학 및 기계 학습에 적합하지만 실행 속도 및 메모리 관리에는 병목 현상이 있습니다.

PHP는 동적 웹 사이트를 구축하는 데 사용되며 해당 핵심 기능에는 다음이 포함됩니다. 1. 데이터베이스와 연결하여 동적 컨텐츠를 생성하고 웹 페이지를 실시간으로 생성합니다. 2. 사용자 상호 작용 및 양식 제출을 처리하고 입력을 확인하고 작업에 응답합니다. 3. 개인화 된 경험을 제공하기 위해 세션 및 사용자 인증을 관리합니다. 4. 성능을 최적화하고 모범 사례를 따라 웹 사이트 효율성 및 보안을 개선하십시오.

PHP는 MySQLI 및 PDO 확장 기능을 사용하여 데이터베이스 작업 및 서버 측 로직 프로세싱에서 상호 작용하고 세션 관리와 같은 기능을 통해 서버 측로 로직을 처리합니다. 1) MySQLI 또는 PDO를 사용하여 데이터베이스에 연결하고 SQL 쿼리를 실행하십시오. 2) 세션 관리 및 기타 기능을 통해 HTTP 요청 및 사용자 상태를 처리합니다. 3) 트랜잭션을 사용하여 데이터베이스 작업의 원자력을 보장하십시오. 4) SQL 주입 방지, 디버깅을 위해 예외 처리 및 폐쇄 연결을 사용하십시오. 5) 인덱싱 및 캐시를 통해 성능을 최적화하고, 읽을 수있는 코드를 작성하고, 오류 처리를 수행하십시오.

PHP에서 전처리 문과 PDO를 사용하면 SQL 주입 공격을 효과적으로 방지 할 수 있습니다. 1) PDO를 사용하여 데이터베이스에 연결하고 오류 모드를 설정하십시오. 2) 준비 방법을 통해 전처리 명세서를 작성하고 자리 표시자를 사용하여 데이터를 전달하고 방법을 실행하십시오. 3) 쿼리 결과를 처리하고 코드의 보안 및 성능을 보장합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.
