假设我有一个包含两行的文件,并且在文件中获得indexOf
子字符串。它以18
返回子字符串的字符。我怎样才能找到这条信息?从文本正文获取一个字符串的行号
var file = [
'var foo = "hello"',
'console.log(foo)',
].join('\n')
var char = file.indexOf('console') // => 18
var line = lineOfChar(file, char) // => 2
假设我有一个包含两行的文件,并且在文件中获得indexOf
子字符串。它以18
返回子字符串的字符。我怎样才能找到这条信息?从文本正文获取一个字符串的行号
var file = [
'var foo = "hello"',
'console.log(foo)',
].join('\n')
var char = file.indexOf('console') // => 18
var line = lineOfChar(file, char) // => 2
一个可能的方式实现这一目标,是要找到像你这样做的字符串:
var index = file.indexOf('console'); // => 18
然后用这个指数来使包含索引之前所有的子字符串:
var tempString = str.substring(0, index);
最后我们计算发生的\n
:
var lineNumber = tempString.split('\n').length;
// You should do - 1 if you want your 'first' line to be 0
我的错误,不知道为什么我这样做。一定是在思考indexOf,而不是我脑海中那么长。将编辑原始答案。 –
什么是str引用? –
var assert = require('assert')
var file = [
'var alpha = "hello"',
'var beta = "hello"',
'var gamma = "hello"',
'var delta = "hello"',
'var episilon = "hello"'
].join('\n')
function getLine (body, charOrString) {
if (!body) return false
if (!charOrString) return false
var char = (typeof charOrString === 'string') ? body.indexOf(charOrString) : charOrString
var subBody = body.substring(0, char)
if (subBody === '') return false
var match = subBody.match(/\n/gi)
if (match) return match.length + 1
return 1
}
assert.equal(getLine(file, 'missing'), false)
assert.equal(getLine(file, 'alpha'), 1)
assert.equal(getLine(file, 'beta'), 2)
assert.equal(getLine(file, 'gamma'), 3)
assert.equal(getLine(file, 'delta'), 4)
assert.equal(getLine(file, 'episilon'), 5)
function lineOf(text, substring){
var line = 0, matchedChars = 0;
for (var i = 0; i < text.length; i++) {
text[i] === substring[matchedChars] ? matchedChars++ : matchedChars = 0;
if (matchedChars === substring.length){
return line;
}
if (text[i] === '\n'){
line++;
}
}
return -1;
}
避免了遍历字符串两次,一次找到子重新寻找新行。
计算'\ n'的数量,直到您到达行号 – depperm