mirror of
https://github.com/nushell/nushell
synced 2025-01-27 20:35:43 +00:00
docs/commands: add from.md, update subcommands (#1712)
This adds a top-level document for the new `from` command, with a list of links of all the subcommands. All the from-* subcommands keep their filename, but the content is updated to use the new subcommand syntax. Needs matching update for to* Ref #1709
This commit is contained in:
parent
3201c90647
commit
8ab2b92405
11 changed files with 111 additions and 59 deletions
|
@ -1,4 +1,4 @@
|
||||||
# from-csv
|
# from csv
|
||||||
|
|
||||||
Converts csv data into table. Use this when nushell cannot determine the input file extension.
|
Converts csv data into table. Use this when nushell cannot determine the input file extension.
|
||||||
|
|
||||||
|
@ -24,10 +24,10 @@ dog, Alfred, 10
|
||||||
chameleon, Linda, 1
|
chameleon, Linda, 1
|
||||||
```
|
```
|
||||||
|
|
||||||
To get a table from `pets.txt` we need to use the `from-csv` command :
|
To get a table from `pets.txt` we need to use the `from csv` command :
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open pets.txt | from-csv
|
> open pets.txt | from csv
|
||||||
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
||||||
# │ animal │ name │ age
|
# │ animal │ name │ age
|
||||||
───┼───────────┼─────────┼──────
|
───┼───────────┼─────────┼──────
|
||||||
|
@ -59,7 +59,7 @@ chameleon; Linda; 1
|
||||||
```
|
```
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open pets.txt | from-csv --separator ';'
|
> open pets.txt | from csv --separator ';'
|
||||||
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
||||||
# │ animal │ name │ age
|
# │ animal │ name │ age
|
||||||
───┼───────────┼─────────┼──────
|
───┼───────────┼─────────┼──────
|
||||||
|
@ -69,20 +69,20 @@ chameleon; Linda; 1
|
||||||
━━━┷━━━━━━━━━━━┷━━━━━━━━━┷━━━━━━
|
━━━┷━━━━━━━━━━━┷━━━━━━━━━┷━━━━━━
|
||||||
```
|
```
|
||||||
|
|
||||||
To use this command to open a csv with separators other than a comma, use the `--raw` switch of `open` to open the csv, otherwise the csv will enter `from-csv` as a table split on commas rather than raw text.
|
To use this command to open a csv with separators other than a comma, use the `--raw` switch of `open` to open the csv, otherwise the csv will enter `from csv` as a table split on commas rather than raw text.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> mv pets.txt pets.csv
|
> mv pets.txt pets.csv
|
||||||
> open pets.csv | from-csv --separator ';'
|
> open pets.csv | from csv --separator ';'
|
||||||
error: Expected a string from pipeline
|
error: Expected a string from pipeline
|
||||||
- shell:1:16
|
- shell:1:16
|
||||||
1 | open pets.csv | from-csv --separator ';'
|
1 | open pets.csv | from csv --separator ';'
|
||||||
| ^^^^^^^^ requires string input
|
| ^^^^^^^^ requires string input
|
||||||
- shell:1:0
|
- shell:1:0
|
||||||
1 | open pets.csv | from-csv --separator ';'
|
1 | open pets.csv | from csv --separator ';'
|
||||||
| value originates from here
|
| value originates from here
|
||||||
|
|
||||||
> open pets.csv --raw | from-csv --separator ';'
|
> open pets.csv --raw | from csv --separator ';'
|
||||||
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
||||||
# │ animal │ name │ age
|
# │ animal │ name │ age
|
||||||
───┼───────────┼─────────┼──────
|
───┼───────────┼─────────┼──────
|
||||||
|
@ -99,18 +99,18 @@ Newlines '\n' are not acceptable separators.
|
||||||
Note that separators are currently provided as strings and need to be wrapped in quotes.
|
Note that separators are currently provided as strings and need to be wrapped in quotes.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open pets.csv --raw | from-csv --separator ;
|
> open pets.csv --raw | from csv --separator ;
|
||||||
- shell:1:43
|
- shell:1:43
|
||||||
1 | open pets.csv --raw | from-csv --separator ;
|
1 | open pets.csv --raw | from csv --separator ;
|
||||||
| ^
|
| ^
|
||||||
```
|
```
|
||||||
|
|
||||||
It is also considered an error to use a separator greater than one char :
|
It is also considered an error to use a separator greater than one char :
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open pets.txt | from-csv --separator '123'
|
> open pets.txt | from csv --separator '123'
|
||||||
error: Expected a single separator char from --separator
|
error: Expected a single separator char from --separator
|
||||||
- shell:1:37
|
- shell:1:37
|
||||||
1 | open pets.txt | from-csv --separator '123'
|
1 | open pets.txt | from csv --separator '123'
|
||||||
| ^^^^^ requires a single character string input
|
| ^^^^^ requires a single character string input
|
||||||
```
|
```
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# from-ics
|
# from ics
|
||||||
|
|
||||||
Parse text as `.ics` and create table.
|
Parse text as `.ics` and create table.
|
||||||
|
|
||||||
Syntax: `from-ics`
|
Syntax: `from ics`
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -20,10 +20,10 @@ UID:4l80f6dcovnriq38g57g07btid@google.com
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
Pass the output of the `open` command to `from-ics` to get a correctly formatted table:
|
Pass the output of the `open` command to `from ics` to get a correctly formatted table:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open calendar.txt | from-ics
|
> open calendar.txt | from ics
|
||||||
───┬────────────────┬──────────────────┬────────────────┬────────────────┬────────────────┬────────────────┬────────────────
|
───┬────────────────┬──────────────────┬────────────────┬────────────────┬────────────────┬────────────────┬────────────────
|
||||||
# │ properties │ events │ alarms │ to-Dos │ journals │ free-busys │ timezones
|
# │ properties │ events │ alarms │ to-Dos │ journals │ free-busys │ timezones
|
||||||
───┼────────────────┼──────────────────┼────────────────┼────────────────┼────────────────┼────────────────┼────────────────
|
───┼────────────────┼──────────────────┼────────────────┼────────────────┼────────────────┼────────────────┼────────────────
|
||||||
|
@ -32,7 +32,7 @@ Pass the output of the `open` command to `from-ics` to get a correctly formatted
|
||||||
```
|
```
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open calendar.txt | from-ics | get events | get properties | where name == "SUMMARY"
|
> open calendar.txt | from ics | get events | get properties | where name == "SUMMARY"
|
||||||
─────┬─────────┬───────────────────────────────────────┬────────
|
─────┬─────────┬───────────────────────────────────────┬────────
|
||||||
# │ name │ value │ params
|
# │ name │ value │ params
|
||||||
─────┼─────────┼───────────────────────────────────────┼────────
|
─────┼─────────┼───────────────────────────────────────┼────────
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# from-json
|
# from json
|
||||||
|
|
||||||
Parse text as `.json` and create table. Use this when nushell cannot dertermine the input file extension.
|
Parse text as `.json` and create table. Use this when nushell cannot dertermine the input file extension.
|
||||||
|
|
||||||
Syntax: `from-json {flags}`
|
Syntax: `from json {flags}`
|
||||||
|
|
||||||
### Flags:
|
### Flags:
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ Syntax: `from-json {flags}`
|
||||||
> open command_from-json
|
> open command_from-json
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
title: "from-json",
|
title: "from json",
|
||||||
type: "command",
|
type: "command",
|
||||||
flags: true
|
flags: true
|
||||||
}
|
}
|
||||||
|
@ -24,10 +24,10 @@ Syntax: `from-json {flags}`
|
||||||
```
|
```
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open command_from-json | from-json
|
> open command_from-json | from json
|
||||||
━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━━
|
━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━━
|
||||||
title │ type │ flags
|
title │ type │ flags
|
||||||
───────────┼─────────┼───────
|
───────────┼─────────┼───────
|
||||||
from-json │ command │ Yes
|
from json │ command │ Yes
|
||||||
━━━━━━━━━━━┷━━━━━━━━━┷━━━━━━━
|
━━━━━━━━━━━┷━━━━━━━━━┷━━━━━━━
|
||||||
```
|
```
|
|
@ -1,6 +1,6 @@
|
||||||
# from-ods
|
# from ods
|
||||||
|
|
||||||
Parses OpenDocument Spreadsheet binary data into a table. `open` calls `from-ods` automatically when the file extension is `ods`. Use this command when `open` is unable to guess the file type from the extension.
|
Parses OpenDocument Spreadsheet binary data into a table. `open` calls `from ods` automatically when the file extension is `ods`. Use this command when `open` is unable to guess the file type from the extension.
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ Length: 4816 (0x12d0) bytes
|
||||||
12a0: 00 61 10 00 00 4d 45 54 41 2d 49 4e 46 2f 6d 61 .a...META-INF/ma
|
12a0: 00 61 10 00 00 4d 45 54 41 2d 49 4e 46 2f 6d 61 .a...META-INF/ma
|
||||||
12b0: 6e 69 66 65 73 74 2e 78 6d 6c 50 4b 05 06 00 00 nifest.xmlPK....
|
12b0: 6e 69 66 65 73 74 2e 78 6d 6c 50 4b 05 06 00 00 nifest.xmlPK....
|
||||||
12c0: 00 00 06 00 06 00 5a 01 00 00 60 11 00 00 00 00 ......Z...`.....
|
12c0: 00 00 06 00 06 00 5a 01 00 00 60 11 00 00 00 00 ......Z...`.....
|
||||||
> open abc.ods --raw | from-ods
|
> open abc.ods --raw | from ods
|
||||||
─────────────────
|
─────────────────
|
||||||
Sheet1
|
Sheet1
|
||||||
─────────────────
|
─────────────────
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# from-toml
|
# from toml
|
||||||
Converts toml data into table. Use this when nushell cannot dertermine the input file extension.
|
Converts toml data into table. Use this when nushell cannot dertermine the input file extension.
|
||||||
|
|
||||||
## Example
|
## Example
|
||||||
|
@ -10,11 +10,11 @@ Let's say we have the following Rust .lock file :
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
The "Cargo.lock" file is actually a .toml file, but the file extension isn't .toml. That's okay, we can use the `from-toml` command :
|
The "Cargo.lock" file is actually a .toml file, but the file extension isn't .toml. That's okay, we can use the `from toml` command :
|
||||||
|
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open Cargo.lock | from-toml
|
> open Cargo.lock | from toml
|
||||||
━━━━━━━━━━━━━━━━┯━━━━━━━━━━━━━━━━━━━
|
━━━━━━━━━━━━━━━━┯━━━━━━━━━━━━━━━━━━━
|
||||||
metadata │ package
|
metadata │ package
|
||||||
────────────────┼───────────────────
|
────────────────┼───────────────────
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# from-tsv
|
# from tsv
|
||||||
|
|
||||||
Parse text as `.tsv` and create table.
|
Parse text as `.tsv` and create table.
|
||||||
|
|
||||||
Syntax: `from-tsv {flags}`
|
Syntax: `from tsv {flags}`
|
||||||
|
|
||||||
### Flags:
|
### Flags:
|
||||||
|
|
||||||
|
@ -22,10 +22,10 @@ Li Lithium
|
||||||
Be Beryllium
|
Be Beryllium
|
||||||
```
|
```
|
||||||
|
|
||||||
If we pass the output of the `open` command to `from-tsv` we get a correct formatted table:
|
If we pass the output of the `open` command to `from tsv` we get a correct formatted table:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open elements.txt | from-tsv
|
> open elements.txt | from tsv
|
||||||
━━━┯━━━━━━━━┯━━━━━━━━━━━
|
━━━┯━━━━━━━━┯━━━━━━━━━━━
|
||||||
# │ Symbol │ Element
|
# │ Symbol │ Element
|
||||||
───┼────────┼───────────
|
───┼────────┼───────────
|
||||||
|
@ -39,7 +39,7 @@ If we pass the output of the `open` command to `from-tsv` we get a correct forma
|
||||||
Using the `--headerless` flag has the following output:
|
Using the `--headerless` flag has the following output:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open elements.txt | from-tsv --headerless
|
> open elements.txt | from tsv --headerless
|
||||||
━━━━┯━━━━━━━━━┯━━━━━━━━━━━
|
━━━━┯━━━━━━━━━┯━━━━━━━━━━━
|
||||||
# │ Column1 │ Column2
|
# │ Column1 │ Column2
|
||||||
────┼─────────┼───────────
|
────┼─────────┼───────────
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# from-vcf
|
# from vcf
|
||||||
|
|
||||||
Parse text as `.vcf` and create table.
|
Parse text as `.vcf` and create table.
|
||||||
|
|
||||||
Syntax: `from-vcf`
|
Syntax: `from vcf`
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -18,10 +18,10 @@ EMAIL;TYPE=INTERNET:john.doe99@gmail.com
|
||||||
...
|
...
|
||||||
```
|
```
|
||||||
|
|
||||||
Pass the output of the `open` command to `from-vcf` to get a correctly formatted table:
|
Pass the output of the `open` command to `from vcf` to get a correctly formatted table:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open contacts.txt | from-vcf
|
> open contacts.txt | from vcf
|
||||||
─────┬─────────────────
|
─────┬─────────────────
|
||||||
# │ properties
|
# │ properties
|
||||||
─────┼─────────────────
|
─────┼─────────────────
|
||||||
|
@ -29,7 +29,7 @@ Pass the output of the `open` command to `from-vcf` to get a correctly formatted
|
||||||
```
|
```
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open contacts.txt | from-vcf | get properties | where $it.name == "FN" | pick value
|
> open contacts.txt | from vcf | get properties | where $it.name == "FN" | pick value
|
||||||
─────┬──────────────────────
|
─────┬──────────────────────
|
||||||
# │ value
|
# │ value
|
||||||
─────┼──────────────────────
|
─────┼──────────────────────
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
# from-xlsx
|
# from xlsx
|
||||||
|
|
||||||
Parses MS Excel binary data into a table. `open` calls `from-xlsx` automatically when the file extension is `xlsx`. Use this command when `open` is unable to guess the file type from the extension.
|
Parses MS Excel binary data into a table. `open` calls `from xlsx` automatically when the file extension is `xlsx`. Use this command when `open` is unable to guess the file type from the extension.
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@ Length: 6344 (0x18c8) bytes
|
||||||
18a0: 6b 73 68 65 65 74 73 2f 73 68 65 65 74 31 2e 78 ksheets/sheet1.x
|
18a0: 6b 73 68 65 65 74 73 2f 73 68 65 65 74 31 2e 78 ksheets/sheet1.x
|
||||||
18b0: 6d 6c 50 4b 05 06 00 00 00 00 0a 00 0a 00 7f 02 mlPK............
|
18b0: 6d 6c 50 4b 05 06 00 00 00 00 0a 00 0a 00 7f 02 mlPK............
|
||||||
18c0: 00 00 33 16 00 00 00 00 ..3.....
|
18c0: 00 00 33 16 00 00 00 00 ..3.....
|
||||||
> open abc.xlsx --raw | from-xlsx
|
> open abc.xlsx --raw | from xlsx
|
||||||
─────────────────
|
─────────────────
|
||||||
Sheet1
|
Sheet1
|
||||||
─────────────────
|
─────────────────
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# from-xml
|
# from xml
|
||||||
|
|
||||||
Parse text as `.xml` and create table. Use this when nushell cannot dertermine the input file extension.
|
Parse text as `.xml` and create table. Use this when nushell cannot dertermine the input file extension.
|
||||||
|
|
||||||
Syntax: `from-xml`
|
Syntax: `from xml`
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -22,10 +22,10 @@ Let's say we've got a file in `xml` format but the file extension is different s
|
||||||
</world>
|
</world>
|
||||||
```
|
```
|
||||||
|
|
||||||
We can use `from-xml` to read the input like a `xml` file:
|
We can use `from xml` to read the input like a `xml` file:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open world.txt | from-xml
|
> open world.txt | from xml
|
||||||
━━━━━━━━━━━━━━━━
|
━━━━━━━━━━━━━━━━
|
||||||
world
|
world
|
||||||
────────────────
|
────────────────
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
# from-yaml
|
# from yaml
|
||||||
|
|
||||||
Parse text as `.yaml/.yml` and create table. Use this when nushell cannot determine the input file extension.
|
Parse text as `.yaml/.yml` and create table. Use this when nushell cannot determine the input file extension.
|
||||||
|
|
||||||
Syntax: `from-yaml`
|
Syntax: `from yaml`
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ flags: false
|
||||||
```
|
```
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
> open command_from-yaml | from-yaml
|
> open command_from-yaml | from yaml
|
||||||
━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━━
|
━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━━
|
||||||
title │ type │ flags
|
title │ type │ flags
|
||||||
───────────┼─────────┼───────
|
───────────┼─────────┼───────
|
||||||
|
|
52
docs/commands/from.md
Normal file
52
docs/commands/from.md
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
# from-csv
|
||||||
|
|
||||||
|
Converts content (string or binary) into a table. The format is specified as a subcommand, like `from csv` or `from json`.
|
||||||
|
|
||||||
|
Use this when nushell cannot determine the input file extension.
|
||||||
|
|
||||||
|
## Available Subcommands
|
||||||
|
|
||||||
|
* [from csv](from-csv.md)
|
||||||
|
* [from ics](from-ics.md)
|
||||||
|
* [from json](from-json.md)
|
||||||
|
* [from ods](from-ods.md)
|
||||||
|
* [from toml](from-toml.md)
|
||||||
|
* [from tsv](from-tsv.md)
|
||||||
|
* [from vcf](from-vcf.md)
|
||||||
|
* [from xlsx](from-csv.md)
|
||||||
|
* [from yaml](from-yaml.md)
|
||||||
|
|
||||||
|
## Example for `from csv`
|
||||||
|
|
||||||
|
Let's say we have the following file :
|
||||||
|
|
||||||
|
```shell
|
||||||
|
> cat pets.txt
|
||||||
|
animal, name, age
|
||||||
|
cat, Tom, 7
|
||||||
|
dog, Alfred, 10
|
||||||
|
chameleon, Linda, 1
|
||||||
|
```
|
||||||
|
|
||||||
|
`pets.txt` is actually a .csv file but it has the .txt extension, `open` is not able to convert it into a table :
|
||||||
|
|
||||||
|
```shell
|
||||||
|
> open pets.txt
|
||||||
|
animal, name, age
|
||||||
|
cat, Tom, 7
|
||||||
|
dog, Alfred, 10
|
||||||
|
chameleon, Linda, 1
|
||||||
|
```
|
||||||
|
|
||||||
|
To get a table from `pets.txt` we need to use the `from csv` command:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
> open pets.txt | from csv
|
||||||
|
━━━┯━━━━━━━━━━━┯━━━━━━━━━┯━━━━━━
|
||||||
|
# │ animal │ name │ age
|
||||||
|
───┼───────────┼─────────┼──────
|
||||||
|
0 │ cat │ Tom │ 7
|
||||||
|
1 │ dog │ Alfred │ 10
|
||||||
|
2 │ chameleon │ Linda │ 1
|
||||||
|
━━━┷━━━━━━━━━━━┷━━━━━━━━━┷━━━━━━
|
||||||
|
```
|
Loading…
Reference in a new issue