0

我正在尝试构建一个简单的页面,该页面将删除一行中第一个引号之前的文本以及文本区域内一行中最后一个引号(包括最后一个引号)之后的文本。

这个问题非常有帮助,让我得到了以下代码:

    $('#desqlize').on('click', function(){
        var lines = $('textarea').val().split('\n');
        var total = ""
        $.each(lines, function(){
            var enteredText = String(this); 
            var m = enteredText.match(/"(.*?)"/);
          total = total + m[1] +'\n'
        })
        $('textarea').val(total);   
    });

但是,如果 textarea 中的文本在该行中有引号,例如下面列出的文本,它也会删除这些引号中的文本。

cmd2.CommandText = cmd2.CommandText & "AND b.ColumnID IN     ("&"'"&REPLACE(level2Array(1,0), ",", "','" )&"'"&") "

有人会像上面那样粘贴一行行,我基本上想从 cmd2 中删除所有内容,直到第一个引号,然后删除每行的最后一个引号。我想保留这两个引号内的所有内容。

提前感谢您的帮助。

4

1 回答 1

4

这应该适用于输入中有引号的所有情况:

var parsed = $('textarea').val().replace(/^[^"]*"(.*)"[^"]*$/, '$1');

或者没有正则表达式:

var ta = $('textarea').val();
var parsed = ta.substring(ta.indexOf('"') + 1, ta.lastIndexOf('"'));

要将其与上面的代码放在上下文中:

$('#desqlize').on('click', function(){
    var lines = $('textarea').val().split('\n');
    var total = ""
    $.each(lines, function(){
        var enteredText = String(this); 
        total = total + enteredText.replace(/^[^"]*"(.*)"[^"]*$/, '$1') + '\n';
        // or, alternatively:
        // total = total + enteredText.substring(enteredText.indexOf('"') + 1, enteredText.lastIndexOf('"'));
    })
    $('textarea').val(total);
});
于 2013-08-29T21:39:03.493 回答