我有一个字典数组,如下所示
$foo = array(
'key1' => 'value 1',
'key1' => 'value 2',
'key2' => 'value 3',
'key2' => 'value 4',
'key3' => 'value 5'
);
正如你所看到的,有重复的钥匙。所有的键都是字符串。数组位于文件中,是手动创建的。它有近1000个条目,可能有许多重复的键。
怎样才能找出哪些键是重复的?
我想要得到的结果是有重复项的键列表:
key1, key2, ...
所以我可以进入文件,修复这些密钥,使它们独一无二。任何格式都可以,这样我就知道那些钥匙的名字了。
key3
没有复制,所以它很好。
任何帮助都将不胜感激。
谢谢。
你们中的大多数人似乎都在告诉我同样的事情:)我知道我不能有多个键。问题是,这是一个字典数组,它是在一个平面文件中手动创建的。创建它的人多次添加相同的键。问题是,一个页面上的key1
具有翻译A
,而在另一个页面上应该有翻译B
,但是由于两个值在我的字典数组中都有相同的键,所以它们都显示相同的值。
发布于 2013-12-23 05:41:38
我假设这是一个一次性的工作,目的是清理文件中的一些输入数据,而不是您需要自动完成的事情。
如果您的数据最初位于CSV类型文件中,并且您可以访问一些GNU工具,则我经常使用以下内容
$ cat filenamv.csv | cut -d, -f1 | sort | uniq -d
这应该是CSV文件的第一列,并打印任何重复的键。
您可能需要阅读各个命令(例如man uniq
),以便在您的示例中只使用正确的参数。
发布于 2013-12-23 05:37:02
不能。一旦定义了数组,这些“重复键”就会被折叠。相应的值将丢失。
发布于 2013-12-23 06:03:11
每当您创建这样的数组时,您的第一个键'key1' => 'value 1'
将被'key1' => 'value 2'
替换,并继续这样做。因此,您将始终有唯一的键和最后的值将被保留。
因此,在将重复的键存储到数组中之前,您必须想出一种消除重复键的方法。
您可能会将它们加载到MySql中,启动一些查询。如果您想这样做,请让我知道,我将帮助您进行查询。
https://stackoverflow.com/questions/20744679
复制相似问题