php - 如何根据关键字输入搜索 CSV 文件并返回多个条目
问题描述
您好,我有一个包含名称、扩展名和单元格的 CSV 文件。一些用户同时拥有分机号和手机号码。我正在尝试在我们的 Intranet 页面上创建搜索,用户将在其中输入关键字(名称、分机或单元格),然后返回所有包含该关键字的结果。我使用 fgetcsv 读取了一个 CSV 文件,但我只能返回扩展名。如果我搜索姓名或手机号码,它将返回一个空白页。这是我的代码:
$value = $_POST["search"];
$file = 'phonelist/PhonelistCSV2.csv';
while (($data = fgetcsv($file)) !== FALSE){
//print_r($data); - this was just a test to see the data printing out. It prints the entire CSV
print_r(array_keys($data,$value));
}
fclose($file);
经过一整天的谷歌搜索并试图让它工作后,我放弃了 fgetcsv。现在我正在尝试使用 CSV 并将其编码为 JSON
$csv=file_get_contents($file); $array=array_map("str_getcsv", explode ("\n",$csv));
$json=json_encode($array);
我打印出 json 数组以验证内容是否与 csv 相同。我创建了一个 javascript 函数来搜索关键字。我只是出于测试目的将值放入 div 中进行测试,但我无法使该功能正常工作
$value = $_POST["search"];
$keyword=json_encode($value);
<script type="text/javascript">
function search(keyword){
return json.filter(({name, ext, cell}) => {
return name.toLowerCase().indexOf(keyword.toLowerCase()) > -1 ||
ext.toLowerCase().indexOf(keyword.toLowerCase()) > -1 ||
cell.toLowerCase().indexOf(keyword.toLowerCase()) > -1
})
}
document.getElementById('test').innerHTML = json; // I tried it this way and
alert(search($keyword);
</script>
<div id="test"></div>
长话短说,我需要一些帮助来创建对我的 Intranet 的搜索,以搜索包含姓名、分机号和手机号码的 CSV 办公室目录。到目前为止,在我尝试过的解决方案中,我只能返回分机号码。我希望它的功能类似于搜索“Tim”,返回所有名称中包含 Tim 的人及其后续扩展名、单元格 # 或两者。
解决方案
您可以对名称等内容进行不区分大小写的搜索,并相应地过滤您的记录。
第一部分只是将 csv 数据放入一个数组中。
<?php
$data =<<<DATA
Neil Buchanan,334,012345678
Tony Hart,314,01234828828
Henri Matisse,392,01234457575
DATA;
$data = array_map('str_getcsv', preg_split('/\R/',$data));
$name_search = function($keyword) use ($data) {
return array_filter($data, function($line) use ($keyword) {
return stristr($line[0], $keyword);
});
};
$results = $name_search('to');
var_export($results);
echo "Next Search\n";
$results = $name_search('he');
var_export($results);
输出:
array (
1 =>
array (
0 => 'Tony Hart',
1 => '314',
2 => '01234828828',
),
)Next Search
array (
2 =>
array (
0 => 'Henri Matisse',
1 => '392',
2 => '01234457575',
),
)
推荐阅读
- javascript - javascript 没有在 html 代码中启用,pycharm IDE
- python - 如何使用opencv-python进行实时计数对象和检测?
- javascript - 朗读时浏览器如何突出显示单词/句子?
- python - 使用 python 修复 JSON 结构
- python-3.x - python - 使用嵌套循环上的递归来查询 ldap
- sql - 将字符串不同的值分配给不同的变量
- java - 为什么我们必须创建一个新对象“输入”而不是直接使用 Scanner.nextLine() ?
- c++11 - 使用来自 DL/so/dyib 的模板 cass
- excel - Python XlsxWriter 条件格式几个单元格以单个单元格中的值为条件
- c++ - 引用错误随机间距c ++