Как вставить значение и ключ в массив - PullRequest
302 голосов
/ 23 января 2010

Посмотрите на этот код:

$GET = array();    
$key = 'one=1';
$rule = explode('=', $key);
/* array_push($GET, $rule[0] => $rule[1]); */

Я ищу что-то вроде этого, чтобы:

print_r($GET);
/* output: $GET[one => 1, two => 2, ...] */

Есть ли функция для этого? (потому что array_push не будет работать таким образом)

Ответы [ 18 ]

665 голосов
/ 23 января 2010

Нет, для ассоциативных массивов нет эквивалента array_push(), потому что нет способа определить следующий ключ.

Вам придется использовать

$arrayname[indexname] = $value;
66 голосов
/ 28 мая 2010

Выдвижение значения в массив автоматически создает для него числовой ключ.

При добавлении пары ключ-значение в массив у вас уже есть ключ, вам не нужно его создавать. Вставка ключа в массив не имеет смысла. Вы можете установить только значение определенного ключа в массиве.

// no key
array_push($array, $value);
// same as:
$array[] = $value;

// key already known
$array[$key] = $value;
54 голосов
/ 22 января 2013

Вы можете использовать оператор объединения (+) для объединения массивов и сохранения ключей добавленного массива. Например:

<?php

$arr1 = array('foo' => 'bar');
$arr2 = array('baz' => 'bof');
$arr3 = $arr1 + $arr2;

print_r($arr3);

// prints:
// array(
//   'foo' => 'bar',
//   'baz' => 'bof',
// );

Так что вы могли бы сделать $_GET += array('one' => 1);.

Более подробная информация об использовании оператора объединения против array_merge приведена в документации по адресу http://php.net/manual/en/function.array-merge.php.

19 голосов
/ 05 мая 2015

Я хотел бы добавить свой ответ в таблицу, и вот он:

//connect to db ...etc
$result_product = /*your mysql query here*/ 
$array_product = array(); 
$i = 0;

foreach ($result_product as $row_product)
{
    $array_product [$i]["id"]= $row_product->id;
    $array_product [$i]["name"]= $row_product->name;
    $i++;
}

//you can encode the array to json if you want to send it to an ajax call
$json_product =  json_encode($array_product);
echo($json_product);

надеюсь, что это кому-нибудь поможет

17 голосов
/ 23 января 2010

Именно то, что сказал Пекка ...

В качестве альтернативы, вы можете использовать array_merge следующим образом:

array_merge($_GET, array($rule[0] => $rule[1]));

Но я бы предпочел метод Пекки, вероятно, так как он намного проще.

7 голосов
/ 06 июня 2015

Это решение, которое может пригодиться для вас

Class Form {
# Declare the input as property
private $Input = [];

# Then push the array to it
public function addTextField($class,$id){
    $this->Input ['type'][] = 'text';
    $this->Input ['class'][] = $class;
    $this->Input ['id'][] = $id;
}

}

$form = new Form();
$form->addTextField('myclass1','myid1');
$form->addTextField('myclass2','myid2');
$form->addTextField('myclass3','myid3');

Когда вы бросаете это. Результат как этот

array (size=3)
  'type' => 
    array (size=3)
      0 => string 'text' (length=4)
      1 => string 'text' (length=4)
      2 => string 'text' (length=4)
  'class' => 
    array (size=3)
      0 => string 'myclass1' (length=8)
      1 => string 'myclass2' (length=8)
      2 => string 'myclass3' (length=8)
  'id' => 
    array (size=3)
      0 => string 'myid1' (length=5)
      1 => string 'myid2' (length=5)
      2 => string 'myid3' (length=5)
7 голосов
/ 28 мая 2010

Я просто искал то же самое, и я понял, что снова мое мышление изменилось, потому что я старая школа. Я возвращаюсь к BASIC и PERL и иногда забываю, как на самом деле все просто в PHP.

Я только что сделал эту функцию, чтобы взять все настройки из базы данных, где их 3 столбца. setkey, item (key) & value (value) и поместите их в массив, называемый settings, используя тот же ключ / value без использования push, как описано выше.

Довольно просто и просто


// Get All Settings
$settings=getGlobalSettings();


// Apply User Theme Choice
$theme_choice = $settings['theme'];

.. etc etc etc ....




function getGlobalSettings(){

    $dbc = mysqli_connect(wds_db_host, wds_db_user, wds_db_pass) or die("MySQL Error: " . mysqli_error());
    mysqli_select_db($dbc, wds_db_name) or die("MySQL Error: " . mysqli_error());
    $MySQL = "SELECT * FROM systemSettings";
    $result = mysqli_query($dbc, $MySQL);
    while($row = mysqli_fetch_array($result)) 
        {
        $settings[$row['item']] = $row['value'];   // NO NEED FOR PUSH
        }
    mysqli_close($dbc);
return $settings;
}


Так как другие посты объясняют ... В php нет необходимости "нажимать" массив, когда вы используете

Ключ => Значение

И ... Нет необходимости сначала определять массив.

$ = массив массив ();

Не нужно определять или нажимать. Просто назначьте $ array [$ key] = $ value; Это автоматически push и объявление одновременно.

Я должен добавить, что по соображениям безопасности (P) или (H) Elpless (P), я имею в виду Программирование для чайников, я имею в виду PHP .... хе-хе, я предлагаю вам использовать эту концепцию только для того, что я намеревался , Любой другой метод может быть угрозой безопасности. Там сделал мой отказ от ответственности!

4 голосов
/ 02 ноября 2015

Немного странно, но у меня это сработало

    $array1 = array("Post Slider", "Post Slider Wide", "Post Slider");
    $array2 = array("Tools Sliders", "Tools Sliders", "modules-test");
    $array3 = array();

    $count = count($array1);

    for($x = 0; $x < $count; $x++){
       $array3[$array1[$x].$x] = $array2[$x];
    }

    foreach($array3 as $key => $value){
        $output_key = substr($key, 0, -1);
        $output_value = $value;
        echo $output_key.": ".$output_value."<br>";
    }
4 голосов
/ 27 мая 2015

Немного поздно, но если вы не возражаете против вложенного массива, вы можете воспользоваться следующим подходом:

$main_array = array(); //Your array that you want to push the value into
$value = 10; //The value you want to push into $main_array
array_push($main_array, array('Key' => $value));

Чтобы уточнить, если вы выводите json_encode ($ main_array) , это будет выглядеть как [{"Key": "10"}]

3 голосов
/ 14 мая 2016
 $arr = array("key1"=>"value1", "key2"=>"value");
    print_r($arr);

// печатает массив ['key1' => "value1", 'key2' => "value2"]

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...