schangxiang@126.com
2025-06-13 f10d68fe7b934ba7ad8e8393f36f20878ed8155d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# Split (matcher)
 
[![build status](https://secure.travis-ci.org/dominictarr/split.png)](http://travis-ci.org/dominictarr/split)
 
Break up a stream and reassemble it so that each line is a chunk. matcher may be a `String`, or a `RegExp` 
 
Example, read every line in a file ...
 
``` js
  fs.createReadStream(file)
    .pipe(split())
    .on('data', function (line) {
      //each chunk now is a seperate line!
    })
 
```
 
`split` takes the same arguments as `string.split` except it defaults to '/\r?\n/' instead of ',', and the optional `limit` paremeter is ignored.
[String#split](https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/String/split)
 
`split` takes an optional options object on it's third argument.
 
``` js
  split(matcher, mapper, options)
```
 
Valid options:
 
* maxLength - The maximum buffer length without seeing a newline or `matcher`,
  if a single line exceeds this, the split stream will emit an error.
 
``` js
  split(JSON.parse, null, { maxLength: 2})
```
 
## keep matched splitter
 
As with `Array#split`, if you split by a regular expression with a matching group,
the matches will be retained in the collection.
 
```
stdin
.pipe(split(/(\r?\n)/))
... //lines + separators.
```
 
 
# NDJ - Newline Delimited Json
 
`split` accepts a function which transforms each line.
 
``` js
fs.createReadStream(file)
  .pipe(split(JSON.parse))
  .on('data', function (obj) {
    //each chunk now is a a js object
  })
  .on('error', function (err) {
    //syntax errors will land here
    //note, this ends the stream.
  })
```
 
# License
 
MIT