Wenn Sie hier sind, wissen Sie wahrscheinlich bereits, dass die Funktion array_map keinen Zugriff auf Array-Schlüssel im Rückruf zulässt. Es kann beim Umgang mit assoziativen Arrays (Arrays mit String-Schlüsseln) äußerst nützlich sein, einen anderen Schlüssel als den Wert zu haben.
Ich zeige Ihnen meinen Anwendungsfall für diese Lösung und die neue Funktion, die ich implementiert habe.
Für weitere technische Artikel können Sie mir auf Linkedin oder X folgen.
Ein häufiger Anwendungsfall in der Praxis für die PHP-Funktion array_map ist die Transformation von Daten aus einer Datenbankabfrage oder einer API-Antwort. Angenommen, Sie verfügen über eine Reihe von Benutzerdaten und möchten die Namen der Benutzer formatieren oder eine bestimmte Information aus jedem Benutzerdatensatz extrahieren.
Stellen Sie sich vor, Sie haben ein Array von Benutzerdatensätzen und jeder Datensatz ist ein assoziatives Array mit Schlüsseln wie Vorname, Nachname und E-Mail:
// Array of user data (e.g., from a database query) $users = [ [ 'first_name' => 'John', 'last_name' => 'Doe', 'email' => 'john.doe@example.com' ], [ 'first_name' => 'Jane', 'last_name' => 'Smith', 'email' => 'jane.smith@example.com' ], [ 'first_name' => 'Bob', 'last_name' => 'Johnson', 'email' => 'bob.johnson@example.com' ] ];
Sie können die Liste der E-Mail-Adressen, an die eine Benachrichtigung gesendet werden soll, ganz einfach extrahieren:
$emails = array_map(function($user) { return $user['email']; }, $users); // Result: ['john.doe@example.com', 'jane.smith@example.com', 'bob.johnson@example.com']
Sie können die Funktion array_map verwenden, um basierend auf ihren Informationen neue Felder zum Benutzerobjekt hinzuzufügen:
// Using array_map to add the avatar field to each user $result = array_map(function($user) { return array_merge( $user, [ 'avatar' => 'https://eu.ui-avatars.com/api/?background=ff7511&color=fff&name='.$user['first_name'] ] ); }, $users); // Output the result var_dump($result);
Ich habe eine Datenextraktion aus einer NoSQL-Datenbank durchgeführt, um ein Diagramm auf meinem Produkt-Dashboard zu erstellen. Die Daten, die ich von der NoSQL-Datenbank erhalte, sehen folgendermaßen aus:
$data = [ "2024-08-25" => ["doc_count" => 523, "score" => 0.2, "skipped" => 0], "2024-08-24" => ["doc_count" => 423, "score" => 0.2, "skipped" => 0], "2024-08-23" => ["doc_count" => 453, "score" => 0.2, "skipped" => 0], "2024-08-22" => ["doc_count" => 267, "score" => 0.2, "skipped" => 0], "2024-08-21" => ["doc_count" => 378, "score" => 0.2, "skipped" => 0], "2024-08-20" => ["doc_count" => 325, "score" => 0.2, "skipped" => 0], "2024-08-19" => ["doc_count" => 501, "score" => 0.2, "skipped" => 0], ];
Aufgrund der Javascript-Bibliothek, die zur Visualisierung von Diagrammen verwendet wird, muss ich diese Daten in das folgende Format umwandeln, um dem Frontend-Entwickler das Leben zu erleichtern:
$result = [ [ "label" => "2024-08-25", "value" => 523 ], [ "label" => "2024-08-24", "value" => 423 ], ... ];
Aber um diese Transformation durchzuführen, benötige ich Zugriff auf den Schlüssel des ursprünglichen Arrays, um ihn in das Feld „Label“ einzufügen. Die Standardfunktion array_map erlaubt jedoch nur den Zugriff auf den Wert.
Hier ist eine Implementierung der Funktion array_map_assoc, die mit assoziativen Arrays funktioniert. Es stellt sowohl den Schlüssel als auch den Wert als Argumente des Rückrufs bereit:
/** * Apply a mapping callback receiving key and value as arguments. * The standard array_map doesn't pass the key to the callback. But in the case of associative arrays, * it could be really helpful. * * array_map_assoc(function ($key, $value) { * ... * }, $items) * * @param callable $callback * @param array $array * @return array */ function array_map_assoc(callable $callback, array $array): array { return array_map(function($key) use ($callback, $array){ return $callback($key, $array[$key]); }, array_keys($array)); }
Jetzt kann ich das ursprüngliche Benutzerarray in das Datenformat für die Javascript-Diagrammbibliothek umwandeln:
$histogram = array_map_assoc(function ($key, $value) { return [ 'label' => $key, 'value' => $value['doc_count'] ]; }, $data);
Seien Sie vorsichtig, da die Funktion array_map_assoc den Status der Zeichenfolgenschlüssel nicht beibehält, sondern ein völlig neues Standardarray generiert.
Ich habe diese Funktion auch als neue Hilfsfunktion zum globalen Namespace meiner Laravel-Anwendung hinzugefügt:
https://inspector.dev/laravel-custom-helper-functions-fast-tips/
Erfahrenere Entwickler denken vielleicht, dass Sie auf den Schlüssel und den Wert zugreifen können, indem Sie einfach eine foreach-Anweisung verwenden:
foreach ($data as $date => $value) { ... }
Bei Verwendung von foreach müssen Sie eine zusätzliche Variable verwenden, um die resultierende Transformation zu speichern, und Sie können den Code nicht in einer „einzeiligen“ Anweisung strukturieren.
// Array of user data (e.g., from a database query) $users = [ [ 'first_name' => 'John', 'last_name' => 'Doe', 'email' => 'john.doe@example.com' ], [ 'first_name' => 'Jane', 'last_name' => 'Smith', 'email' => 'jane.smith@example.com' ], [ 'first_name' => 'Bob', 'last_name' => 'Johnson', 'email' => 'bob.johnson@example.com' ] ];
Für weitere technische Artikel können Sie mir auf Linkedin oder X folgen.
Inspector ist ein Tool zur Codeausführungsüberwachung, das speziell für Softwareentwickler entwickelt wurde. Sie müssen nichts auf Serverebene installieren. Installieren Sie einfach das Paket Laravel oder Symfony und schon kann es losgehen.
Wenn Sie nach HTTP-Überwachung, Einblicken in Datenbankabfragen und der Möglichkeit suchen, Warnungen und Benachrichtigungen an Ihre bevorzugte Messaging-Umgebung weiterzuleiten, testen Sie Inspector kostenlos. Registrieren Sie Ihr Konto.
Oder erfahren Sie mehr auf der Website: https://inspector.dev
Das obige ist der detaillierte Inhalt vonPHP array_map für assoziatives Array – Schnelle Tipps. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!