以字符串为索引的 PHP 数组数组

标签 php arrays key

我不是 PHP/MySql 方面的专家,所以我关于如何处理多语言网站并使 PHP 代码可读的第一个想法如下:

1) 创建一个包含“word、en、it、de、fr”字段的表,每个字段对应我要翻译的每个字符串。例如:

 WORD        EN        IT        DE        FR
 title       HomePage  Pagina              No Idea
 thanks      Thank You Grazie    Danke     Merci

2)将表存储在字符串数组的数组中,以便我可以通过以下方式访问它:

 print $word["thanks"]["it"];

恕我直言,这将使 PHP 代码非常可读(性能并不重要)。

所以,我编写了这段代码来从数据库读取数据,如果翻译为空,我用“XX中的单词缺失”填充数组(为了避免粘贴所有相同的代码,我只显示你的情况):

 $s = "SELECT word, it, en, de, fr FROM languages";
 $result = $conn->query($s);
 while ($r = $result->fetch_array(MYSQLI_ASSOC)) {
   $word = $r["word"];
   $it = $r["it"];
   // and DE and EN and FR...
   if ($it != "")
     $w["$word"]["$it"] = $it;
   else
     $w["$word"]["$it"] = $word." IT missing";
   // and DE and EN and FR...
 }   

我尝试添加双引号,我尝试删除它们...但是每次我打印 $w 变量时,它总是空的。从数据库读取的中间变量看起来没问题。

我做错了什么?谢谢。

最佳答案

测试一下。

<?php
$s = "SELECT word, it, en, de, fr FROM languages";
$result = $conn->query($s);
$languages = array('it', 'en', 'de', 'fr');
while ($r = $result->fetch_array(MYSQLI_ASSOC)) {
    foreach ($languages as $lang) {
        $word = strval(trim($r["word"]));
        $translated_word = strval(trim($r[$lang]));
        (strlen($translated_word) > 0) ? $w[$word][$lang] = $translated_word : 
                $w[$word][$lang] = $word . " " . strtoupper($lang) . " missing";
    }
}   

ZioBit 编辑:虚拟文本,因为 SO 不允许我修改单个字符;)

关于以字符串为索引的 PHP 数组数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31774269/

相关文章:

php - 将多个字段放在一个 MYSQL 行中

php - 使 MySQL 条目过期

javascript - 都使用 ajax 提交数据并加载消息

c++ - 动态二维数组 : int (*ptr)[4] = new int[7][4];

c++ - 将 'sort' 与字符数组一起使用 (C++)

php - 2CheckOut-错误 : Bad Request - Parameter error

c - 如何在 C 函数中接收 char 数组?

c# - Entity Framework Code First 一对一关系

Swift - 是什么决定了字典集合的顺序?

C# : Using hashtables to store two of the same value. 这可能吗?