本文介绍如何从 php 中类似 `@loc = 1, @username = tom,` 的字符串格式中,准确提取键(如 loc、username)和对应值,并构造成关联数组,便于后续调用(如 `$vars['username']`)。
在实际开发中,我们偶尔会遇到结构不规范但具有一定规律的字符串数据——例如从某些旧系统、日志或自定义协议返回的 Header 字段,其内容并非标准 JSON 或序列化格式,而是以 @键 = 值, 形式拼接的文本。此时直接使用数组下标(如 $result['Header']['@USERNAME'])无法访问,因为 $result['Header'] 实际是一个纯字符串

正确的处理思路是:先解析字符串,再构造关联数组。推荐使用正则表达式配合 preg_match_all() 提取所有 @key = value 对,再用 array_combine() 绑定键与值:
// 假设 $result['Header'] 的值为:'@LOC = 1, @USERNAME = Tom,'
$headerStr = $result['Header'];
// 使用正则匹配所有 '@{key} = {value},' 模式(支持空格、忽略大小写)
preg_match_all('/@(\w+)\s*=\s*([^,]+?),/', $headerStr, $matches);
// $matches[1] 是所有键(如 ['LOC', 'USERNAME']),$matches[2] 是对应值(如 ['1', 'Tom'])
if (!empty($matches[1]) && !empty($matches[2])) {
$vars = array_combine($matches[1], array_map('trim', $matches[2]));
echo $vars['USERNAME']; // 输出:Tom
print_r($vars);
} else {
echo "未匹配到有效的键值对";
}✅ 关键说明:
⚠️ 注意事项:
function parseHeaderString(string $header): array {
preg_match_all('/@(\w+)\s*=\s*([^,]+?),/', $header, $m);
return !empty($m[1]) ? array_combine($m[1], array_map('trim', $m[2])) : [];
}
// 调用:$data = parseHeaderString($result['Header']);通过该方法,你不仅能获取 @USERNAME,还能统一管理所有 Header 字段,代码清晰、可维护性强,且完全符合 PHP 最佳实践。