查找字符串中第一个最长的单词,不包括符号

时间:2013-06-30 04:38:37

标签: javascript

function longestWord(string) {
    var str = string.split(" ");
    var longest = 0;
    var word = null;
    for (var i = 0; i < str.length; i++) {
        var checkedLetters = "";
        for (var j = 0; j < str[j].length; j++) {
            if (j == /[^a-zA-Z]/) {
                checkedLetters += j;
            }
        if (longest < checkedLetters.length) {
            longest = checkedLetters.length;
            word = checkedLetters;
           }
        }
    }
    return word;
}

我使用正则表达式有什么问题吗?当我调用longestWord(“你好,我在这里”)时,我希望它返回“Hello”(不带逗号),但它返回null。

4 个答案:

答案 0 :(得分:4)

刚刚写了这个小片段,可能会帮助你:

function longestWord(string){
    return string.match(/[a-zA-Z]+/g)
               .reduce(function(a,b){
                    return a.length>=b.length?a:b;
               })
}

/[a-zA-Z]+/g匹配字符串中的所有单词,并返回它们的数组。当在此RegEx上运行时,上面的测试字符串("Hello, I am here")将变为["Hello","I","am","here"]

一旦我拥有这个数组,只需循环查找最长的单词即可。我使用.reduce完成了这项工作。

答案 1 :(得分:2)

您的代码中存在一些错误:

for (var j = 0; j < str[j].length; j++) {

应该是

 for (var j = 0; j < str[i].length; j++) {

并且

if (j == /[^a-zA-Z]/) {

应该是:

if (/[a-zA-Z]/.test(str[i][j])) {

您的最终代码应为:

function longestWord(string) {
    var str = string.split(" ");
    var longest = 0;
    var word = null;
    for (var i = 0; i < str.length; i++) {
        var checkedLetters = "";
        for (var j = 0; j < str[i].length; j++) {
            if (/[a-zA-Z]/.test(str[i][j])) {
                checkedLetters += str[i][j];
            }
        }
        if (longest < checkedLetters.length) {
            longest = checkedLetters.length;
            word = checkedLetters;
        }
    }
    return word;
}

检查demo

答案 2 :(得分:1)

关于如何使用正则表达式的大(非拼写错误)问题是该方法是.test; ==将测试字符串是否等于正则表达式的字符串表示形式。

只需使用.match和一点sort魔法!

function longestWord(string){
    var words = string.match(/\w+/g);
    words.sort(function(a, b) { return b.length - a.length; });
    // Firefox 22.0 promotion:
    // words.sort((a, b) => a.length - b.length);

    return words[0];
}

答案 3 :(得分:0)

您不需要使用Regex,只需使用.length搜索最长的字符串。

function longestWord(string) {

    var str = string.replace(/[\.,-\/#!$%\^&\*;:{}=\-_`~()]/g,"").split(" ");
    longest = str[0].length;
    longestWord = str[0];

    for (var i = 1; i < str.length; i++) {
        if (longest < str[i].length) {
            longest = str[i].length;
            longestWord= str[i];
           }
        }

return longestWord;
}

编辑:你必须使用一些正则表达式...