<?xml version="1.0" encoding="iso-8859-1"?> <!-- $Revision: 1.11 $ --> <!-- splitted from ./en/functions/array.xml, last change in rev 1.107 --> <refentry id="function.array-flip"> <refnamediv> <refname>array_flip</refname> <refpurpose>Exchanges all keys with their associated values in an array</refpurpose> </refnamediv> <refsect1> <title>Description</title> <methodsynopsis> <type>array</type><methodname>array_flip</methodname> <methodparam><type>array</type><parameter>trans</parameter></methodparam> </methodsynopsis> <para> <function>array_flip</function> returns an <type>array</type> in flip order, i.e. keys from <parameter>trans</parameter> become values and values from <parameter>trans</parameter> become keys. </para> <para> Note that the values of <parameter>trans</parameter> need to be valid keys, i.e. they need to be either <type>integer</type> or <type>string</type>. A warning will be emitted if a value has the wrong type, and the key/value pair in question <emphasis>will not be flipped</emphasis>. </para> <para> If a value has several occurrences, the latest key will be used as its values, and all others will be lost. </para> <para> <function>array_flip</function> returns &false; if it fails. </para> <para> <example> <title><function>array_flip</function> example</title> <programlisting role="php"> <![CDATA[ <?php $trans = array_flip($trans); $original = strtr($str, $trans); ?> ]]> </programlisting> </example> </para> <para> <example> <title><function>array_flip</function> example : collision</title> <programlisting role="php"> <![CDATA[ <?php $trans = array("a" => 1, "b" => 1, "c" => 2); $trans = array_flip($trans); print_r($trans); ?> ]]> </programlisting> <para> now <varname>$trans</varname> is: </para> <screen> <![CDATA[ Array ( [1] => b [2] => c ) ]]> </screen> </example> </para> <para> See also <function>array_values</function>, <function>array_keys</function>, and <function>array_reverse</function>. </para> </refsect1> </refentry> <!-- Keep this comment at the end of the file Local variables: mode: sgml sgml-omittag:t sgml-shorttag:t sgml-minimize-attributes:nil sgml-always-quote-attributes:t sgml-indent-step:1 sgml-indent-data:t indent-tabs-mode:nil sgml-parent-document:nil sgml-default-dtd-file:"../../../../manual.ced" sgml-exposed-tags:nil sgml-local-catalogs:nil sgml-local-ecat-files:nil End: vim600: syn=xml fen fdm=syntax fdl=2 si vim: et tw=78 syn=sgml vi: ts=1 sw=1 -->