当第一个数组键未知时,如何在第一个数组键的开头添加a: ?


How can I add a : to the beginning of the first array key when the first array key is unknown?

我试图动态地将类属性添加到PDO准备的语句中。为了实现这一点,我需要创建一个数组,它将从类中获取属性,将它们放入一个数组中,并在每个键的开头添加一个:。然后,用逗号分隔每个键。我最接近的方法是使用:

foreach ($property as $field)
   $propertyValues = implode(", :", array_keys($property));
return $propertyValues;
}  

得到
用户名:密码

我只需要一种方法来添加一个:到第一个键,在这种情况下是用户名。所以它看起来像

:用户名:密码

但是请记住,我正在尝试使其动态,以便我可以将其功能扩展到其他类,并且我并不总是知道第一个数组键是什么。

如果你有兴趣阅读整个课程,这里是:

<?php 
require_once("../config/main.php");
class Database{
protected static $dbFields = array('username', 'password');
public $dbConnection;
public $tableName = 'users';
public $id;
public $username;
public $password;
public function __construct() {
$this->connect();
}
public function connect(){
try {
$this->dbConnection = new PDO("mysql:host=".DB_SERVER."; dbname=".DB_NAME, DB_USER,  DB_PASS);
} catch (PDOException $e) {
echo 'Connection failed: ' . $e->getMessage();
}
}
public function properties() {
$properties = array();
foreach (self::$dbFields as $field) {
    if (isset($this->field) || property_exists($this, $field)) {
        $properties[$field] = $this->$field;
    }
}
return $properties;
}
public function property_values() {  
$property = $this->properties();
    $propertyValues = implode(", :", array_keys($property));
return $propertyValues;
}
public function insert(){
    // this is where all the is going to happen. it's a work in progress
// $sql  = "INSERT INTO". $this->tableName. " (";
// $sql .= implode(", ",array_keys($this->properties()));
// $sql .= ")VALUES(". ;

// $q = $this->db->prepare($sql);
// $q->execute(array('John', 'hula'));
}

}
$database = new Database();
$vals = $database->property_values();
print_r($vals);
?>
$propertyValues = ':'. implode(", :", array_keys($property));

要获取第一个数组键,可以使用简单的:

reset($array);
$firstkey = key($array);

由于您还需要值(不能更改键,只能取消旧键并设置新键),因此您可以使用:

$value = reset($array);
$firstkey = key($array);
unset($array[$firstkey]);
$array[':'.$firstkey] = $value;
然而

这并不是最干净的方法。正如经常发生的那样,当实际上有一个更清晰的方法可用时,你已经变得专注于调整"你的"方法来工作。

一个方法:

$keys = array_map(function($key) { return ':'.$key; }, array_keys($property));
$property = array_combine($keys, $property);

现在所有的属性名前面都加了一个':'

另一种方法是手动在前面加上':';Webbiedave比我先做到了