1

我正在尝试编写一个正则表达式,它将一些样板 SQL 代码重新格式化为一个更干净的版本。这是一个例子。

我有:

SELECT
    [Person].[Name]
    [Person].[Address],
    [Sales].[TotalAmount]

我想:

SELECT
    [Name]        = [Person].[Name],
    [Address]     = [Person].[Address],
    [TotalAmount] = [Sales].[TotalAmount]

我可以写一个表达式将字段名称移动到赋值语句的左侧,没问题。棘手的部分是正确的间距——有没有办法在替换中使用匹配的长度?另外,要使用最长匹配的长度吗?这样 "[Name]" 后跟 length("TotalAmount") - length("Name") = 7 个空格,"[Address]" 后跟 length("TotalAmount") - length("Address") = 4 个空格,等等?

我不确定这对正则表达式是否可行,但我想我会把它扔在那里,希望有一些正则表达式大师知道如何做到这一点。

4

1 回答 1

0

关闭语言,但仍将发布。

在 PHP 中preg_replace_callback(),您可以使用正则表达式匹配字符串,然后使用 PHP 处理它。所以这是一个完整的 PHP 解决方案,请注意您需要PHP 5.3+

$sql = 'SELECT
    [Person].[Name]
    [Person].[Address],
    [Sales].[TotalAmount]';

preg_match_all('#\[[^]]+\]\.(\[[^]]+\])#', $sql, $found); // Match
$max = max(array_map('strlen', $found[1])); // Find max length

$new = preg_replace_callback('#\[[^]]+\]\.(\[[^]]+\])#', function($m)use($max){
    $string = $m[1].str_repeat(' ',$max - strlen($m[1])).' = '.$m[0]; // Constructing
    return($string);
}, $sql);
echo $new;

输出:

SELECT
    [Name]        = [Person].[Name]
    [Address]     = [Person].[Address],
    [TotalAmount] = [Sales].[TotalAmount]

Online demo

于 2013-06-14T09:31:27.923 回答