shlex

Node.js port of Python's shlex shell-like lexer

MIT 11 个版本
安装
npm install shlex
yarn add shlex
pnpm add shlex
bun add shlex
README

node-shlex

Build Status

node-shlex is a JavaScript module for quoting and parsing shell commands.

The API was inspired by the shlex module from the Python Standard Library. However, the Python implementation is fairly complex, and supports a confusing matrix of modes that is not replicated here. node-shlex always operates in what the Python module calls "POSIX mode."

As of version 2.0.0, Bash's ANSI C strings ($'x') and locale-specific translation strings ($"x") are supported. This diverges from the Python shlex behavior but makes parsing more accurate.

Note that node-shlex does not attempt to split on or otherwise parse operators (such as 2>/dev/null) or comments, and it does not perform variable interpolation.

Usage

shlex.join()

import { join } from 'shlex'
join(["ls", "-al", '/'])  // returns: 'ls -al /'
join([ 'rm', '-f', '/Volumes/Macintosh HD' ])  // returns: "rm -f '/Volumes/Macintosh HD'"

shlex.quote()

import { quote } from 'shlex'
quote("abc")      // returns: abc
quote("abc def")  // returns: 'abc def'
quote("can't")    // returns: 'can'"'"'t'

shlex.split()

import { split } from 'shlex'
split('ls -al /')  // returns: [ 'ls', '-al', '/' ]
split('rm -f "/Volumes/Macintosh HD"')  // returns: [ 'rm', '-f', '/Volumes/Macintosh HD' ]
版本列表
3.0.0 2025-06-28
2.1.2 2022-06-24
2.1.1 2022-06-24
2.1.0 2021-05-25
2.0.2 2020-04-06
2.0.1 2019-03-25
2.0.0 2019-03-24
1.0.3 2018-09-06
1.0.2 2018-06-24
1.0.1 2018-06-19
1.0.0 2018-06-19