【发布时间】:2012-11-25 06:25:15
【问题描述】:
我正在使用 PHP 读取制表符分隔的 CSV 文件和管道分隔的 TXT 文件。不幸的是,即使字符(看起来)完全相同,我也无法进行字符串比较。我使用修剪来确保清除隐藏的字符,甚至尝试将类型转换为字符串。
Var dump 显示它们明显不同,但我不确定如何使它们相同?
// read in CSV file
$fh = fopen($mapping_date, 'r');
$mapping_data = fread($fh, filesize($mapping_date));
...
// use str_getcsv to put each line into an array
// get values out that I want to compare
$this_strategy = (string)trim($strategy_name);
$row_strategy = (string)trim($row3[_Strategy_Name]);
if($this_strategy == $row_strategy) { // do something }
var_dump($this_strategy);
Vardump: string(16) "Low Spend ($0.2)"
var_dump($row_strategy);
Vardump: string(31) "Low Spend ($0.2)"
我这辈子都想不通如何完成这项工作。
【问题讨论】:
-
我应该补充一点,我尝试了 strcmp 并尝试使用 inarray (因为它最初在数组中) if(in_array ($row_strategy, $row1["Strategies"], false))
-
您是否使用与打开 TXT 文件相同的方法打开 CSV 文件?
-
长度不同的事实可能表明字符串编码存在问题。打印出每个字符串的每个字符。见stackoverflow.com/a/6663560/384155
-
是的,使用相同的方法(fopen 和 str_getcsv),但读取的两个文件的生成方式不同(这可能是字节不同的原因)。这是十六进制转储,明显不同 字符串 1:%4c%6f%77%20%53%70%65%6e%64%20%28%24%30%2e%32%29 字符串 2:%4c%00 %6f%00%77%00%20%00%53%00%70%00%65%00%6e%00%64%00%20%00%28%00%24%00%30%00%2e %00%32%00%29
-
它来自某种数据库吗?数据库中使用什么编码?如何插入数据?
标签: php string comparison