nodejs child_process输出的命令行被截断怎么办?

广告位招租
扫码页面底部二维码联系

nodejs的child_process本文作者:唐霜,转载请注明出处。【未经授权禁止转载】可以直接用于执行命令,利用spawn轻松转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】通过stdout, stderr获取输出【未经授权禁止转载】未经授权,禁止复制转载。的内容。但是,在获取内容时,有一个不好的本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】地方,stdout, stderr输出的本文作者:唐霜,转载请注明出处。【本文受版权保护】内容是以流的形式,需要通过监听data来本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。读取流式输出,而这个过程中,它的输出可能【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】比较随机,断句并不一定是某条命令行语句执转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】行后的完整输出,而可能是命令行中到一定时本文版权归作者所有,未经授权不得转载。【作者:唐霜】间就输出,这个时候就会造成断句混乱:

转载请注明出处:www.tangshuang.net【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。
const { spawn } = require('child_process')
const child = spawn('npm', ['install', '--verbose'], { cwd: process.cwd() })
child.stdout.on('data', fn)
child.stderr.on('data', fn)

function fn(data) {
本文版权归作者所有,未经授权不得转载。 console.log(data.to【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】String())
原创内容,盗版必究。 }

本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net

【转载请注明来源】未经授权,禁止复制转载。【转载请注明来源】原创内容,盗版必究。

这就比较麻烦,界面上显示的内容错位了。解未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。决的办法是什么呢?其实你不要用conso本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】le.log,而是要自己写一个输出逻辑,未经授权,禁止复制转载。【原创内容,转载请注明出处】两个流并行,对于stdout输出的内容直【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。接连接到上一个输出的就可以了。另外写一个著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】流,当有新的内容被加入的时候,通过触发一【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。个函数,检查内容的最后一个\r\n,然后【未经授权禁止转载】【原创内容,转载请注明出处】在这里截断,把前面的内容输出即可。

未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。

下面是我实现的一个函数:

著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】
export function execute(cmd, callback, cwd = process.cwd()) {
  return new Promise((resolve, reject) => {
    let items = cmd.split(' ')
    let exe = items.shift()
    let processor = spawn(exe, items, { cwd })
    let collect = () => {
      let str = ''
      let print = () => {
        let lines = str.split(/[\n|\r\n]/)
        str = lines.pop()
        let contents = lines.join('\r\n')
        if (str === '') { // 如果本来内容就是完整断句的,这里进行修正,表示结尾是正常断句的
          contents += '\r\n'
        }
        callback(contents)
      }
      return (data) => {
        str += data.toString()
        print()
      }
    }
    if (typeof callback === 'function') {
      processor.stdout.on('data', collect())
      processor.stderr.on('data', collect())
    }
    processor.on('error', reject)
    processor.on('close', resolve)
  })
}

用法很简单

【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。
await execute('npm install --verbose', (contents) => console.log(contents))

这样,用console.log打印的内容【原创不易,请尊重版权】【原创内容,转载请注明出处】,就不会出现断句不正常的问题了。

【本文首发于唐霜的博客】【原创内容,转载请注明出处】【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。

2018-10-17 8939 ,

为价值买单,打赏一杯咖啡

本文价值89.39RMB