我有一个txt文件,其中包含一些内容,我想使用linux命令将其转换为yml格式。
示例Txt文件
mac
linux
windows
我想要下面的输出。就像我想添加"os“关键字并通过linux命令将其转换为yml一样。
os:
- mac
- linux
- windows
有人能帮我弄到这个吗,谢谢
我的文件包含以下几行
File.txt
Unix is good
Linux and unix is different?
Linux is also good, then what about unix?
这里我要输出
(1st line blank)
Linix and
Linux is also good, then what about
在这里vi命令或任何其他命令都会给出这个输出?搜索特定的单词,如果这是对的话,然后删除那个词,然后删除该行中的所有单词。
对于grep特定的关键字和它的内容,我有一个问题。这是示例文件,实际文件比这个文件大。
示例
user@linux:~$ cat url.txt
abcrandomtextdef another random text blablabla
another random iwantthis text abcrandomtextdef url=https://www.google.com ghirandomtextjkl
ghirandomtextjkl another random text yadayada
wxyz iwantthis abcdef url=yahoo.com yaday
我正在尝试替换文件中出现的第一个字符串。例如,试图用linux取代第一个foo
sample.txt
Hi foo bar
This is again foo bar.
命令:sed '0,/foo/s//linux/' sample.txt
上述命令的实际输出(基本不变)
Hi foo bar
This is again foo bar.
我的预期产出如下
Hi linux bar
This is again foo bar.
这里有人能帮忙吗?
假设我有一个以Unix格式创建的文件。现在,在将该文件发送到窗口之前,必须完成EOL转换。
我需要在bash中这样做,这就是我到目前为止所拥有的:
为了简单起见,假设我的文件名为file_linux.txt,它提供以下输出:
cat -A file_linux.txt
first line$
second line$
third line$
file file_linux.txt
file_linux.txt: ASCII text
因此,似乎我只需要在$符号之前添加回车(^M或\r)。
我的想法是使用sed将$替换为\r$,方法如下:
sed 's/$/\r$/g' fil
我最近读了一篇关于在汇编中使用printf和scanf的文章:
特别是它说“在printf中,换行符打印一个换行符,然后(如果输出处于行缓冲模式,很可能是这样),刷新内部输出缓冲区,这样你就可以真正看到结果了。所以当你去掉10的时候,没有刷新,也看不到输出。”
但是,如果我不想在程序集文件中的输出后加上换行符,我不知道该怎么办。下面是我编写的一个简单的测试文件,用于尝试在不换行符的情况下打印:
extern printf
LINUX equ 80H ; interupt number for entering Linux kernel
EXIT