AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-558210

R 9000's questions

Martin Hope
R 9000
Asked: 2023-03-03 00:48:24 +0800 CST

从街道号码中拆分/提取街道名称的终极工具

  • 5

我有一些不同国际格式的addresses.csv

Example Street 1
Teststraße 2
Teststr. 1-5
Baker Street 221b
221B Baker Street
19th Ave 3B
3B 2nd Ave
1-3 2nd Mount x Ave
105 Lock St # 219
Test Street, 1
BookAve, 54, Extra Text 123#

例如我们在德国写作Teststraße 2,在美国2 Test Street

有没有办法分离/提取所有街道名称和街道号码? 输出名称.csv

Example Street
Teststraße
Teststr.
Baker Street
Baker Street
19th Ave
2nd Ave
2nd Mount Good Ave
Lock St # 219
Test Street
BookAve

输出数字.csv

1
2
1-5
221b
221B
3B
3B
1-3
105
1
54

输出-extra_text.csv











Extra Text 123#

我正在使用 macOS 13.. shell 是 zsh 5.8.1 或 bash-3.2


我的想法是:您可以像这样先对地址进行排序:

x=The-adress-line;
if [ x = "begins with a letter"];
    then 
    if [ x = "begins with a letter + number + SPACE"];
        then
        echo 'something like "1A Street"';
        # NUMBER = '1A' / NAME = 'Street'
    else
        echo 'It begins with the STREET-NAME';
    fi;
elif [ x = "begins with a number"];
    then
    echo 'maybe STREET-NAME like "19th Ave 19B" or STREET-NUMBER like "19B Street"';
    # NUMBER = '19B' / NAME = '19th Ave' or 'Street'
    if [ x = "begins with a number + SPACE"];
        then
        echo 'It begins with the STREET-NUMBER like "1 Street"';
        # NUMBER = '1' / NAME = 'Street'
    elif [ x = "is (number)(text)(space)(text)(number(maybe-text))"];
        then
            echo 'For example 19th Street 19B -> The last number+text is the number (19B)'
            # NUMBER = '19B' / NAME = '19th Street'
    elif [ x = "is (number(maybe-text))(space)(number)(text)(space)(text)"];
        then
        echo 'For example 19B 19th Street -> The first number+text is the number (19B)'
            # NUMBER = '19B' / NAME = '19th Street'
    else
        echo 'INVALID';
else
    echo 'INVALID';
fi;
text-processing
  • 1 个回答
  • 96 Views
Martin Hope
R 9000
Asked: 2023-02-26 23:27:20 +0800 CST

将一个文件的内容插入到另一个文件中并在模式之间替换它

  • 4

我有一个file1.html:

<!doctype html>
<html>
<head>
</head>
<body>
    text
    <!-- start-replacing -->
<p>more text1</p>
<p>more text2</p>
    <!-- end-replacing -->
    other text
</body>
</html>

和一个file2.txt

<p>some text</p>
<div>some other text</div>

现在我正在寻找一个命令来替换之间的所有内容

<!-- start-replacing -->和<!-- end-replacing -->

包含 file2.txt 的内容

output.html应该是:

<!doctype html>
<html>
<head>
</head>
<body>
    text
    <!-- start-replacing -->
<p>some text</p>
<div>some other text</div>
    <!-- end-replacing -->
    other text
</body>
</html>
shell
  • 3 个回答
  • 70 Views
Martin Hope
R 9000
Asked: 2023-02-26 11:34:33 +0800 CST

printf "%.3f" ${带换行符的变量} - \n 错误

  • 7

就像这里一样,我有一个file.csv,其中的数字用引号引起来:

"0.2"
"0.3339"
"0.111111"

要舍入数字(小数点后 3 位),此解决方案效果很好:

printf "%.03f\n" $(sed 's/\"//g' file.csv)

但现在我想存储sed 's/\"//g' file.csv为变量

var_sed=$(sed 's/\"//g' file.csv);
printf "%.03f\n" ${var_sed}

不起作用。输出是

zsh: bad math expression: operator expected at `0.3339\n0.1...'
0.000

所以问题是var_sed传递\n给printf "%.03f\n".

我知道的唯一解决方案是:

var_sed=$(sed 's/\"//g' file.csv);
printf "%.03f\n" $(echo ${var_sed})
  1. 也许有更清洁的方法。
  2. 我也想加入printf "%.03f\n"这样的函数:
printf_function () { printf "%.03f\n" $1;}

但这不起作用:

printf_function () { printf "%.03f\n" $1;};
var_sed=$(sed 's/\"//g' file.csv);
printf_function ${var_sed}

也printf_function $(echo ${var_sed})没有工作。

______________________________________________________________

为什么我尝试将文件保存在变量中? ______________________________________________________________

事实是我实际上想把命令sed放在一个函数中。对不起,我把它作为一个变量来(试图)简化问题。

我的脚本是

sed_01 () { sed 's/\"$// ; s/^\"// ; s/something_else//g' $1;};
printf_03 () { printf "%.03f\n" $1;};
printf_03 "$(sed_01 file.csv)"

正如下面评论中提到的,它适用于 bash。

输出:

"0.200"
"0.334"
"0.111"

但在 zsh 中输出:是:

printf_03: bad math expression: operator expected at `0.3339\n0.1...'
0.000
shell
  • 1 个回答
  • 93 Views
Martin Hope
R 9000
Asked: 2023-02-24 08:21:53 +0800 CST

将 csv 中的许多值舍入为 3 位小数(printf?)

  • 10

我有这样的粘贴命令 paste -d , file1.csv file2.csv file3.csv

file2.csv 包含这样的数字

0.2
0.3339
0.111111

我希望 file2.csv 中的值具有 3 位小数,如下所示:

0.200
0.334
0.111

对于一个值,这是有效的:

printf "%.3f" "0.3339"->0.334

但是对于 file2.csv 中的多个值,这是行不通的:

paste -d , file1.csv <(printf %s "%.3f" "$(< file2.csv)") file3.csv

也许有一个好的解决方案?

csv
  • 3 个回答
  • 406 Views
Martin Hope
R 9000
Asked: 2023-02-13 11:33:13 +0800 CST

合并具有不同行数的 .csv 文件

  • 5

在这里我已经问过类似的问题。

现在我有 3 个 .csv 文件,但其中一个只有 1 行。

文件1.csv

dog
cats
mouse

文件2.csv

001a
002a
003c

文件3.csv

WORD

输出应该是

dog,001a,WORD
cats,002a,WORD
mouse,003c,WORD

一个解决方案(来自我之前的问题)是:

paste -d, file1.csv file2.csv | awk -F, '{print $1 "," $2 ",WORD"}'

但是“WORD”在这里只是写入而不是从 file3.csv 中读取。

有没有办法告诉paste用 file3.csv 填充每一行?或者也许将 file3.csv 保存为变量并将其提供给awk?

shell
  • 2 个回答
  • 41 Views
Martin Hope
R 9000
Asked: 2023-02-11 08:40:37 +0800 CST

将 .csv 文件与每行之间的文本组合

  • 6

我有两个(或更多)文件:

文件1.csv

dog
cats
mouse

文件2.csv

001a
002a
003c

如果我使用paste file1.csv file2.csv输出是

dog 001a
cats    002a
mouse   003c

我当然可以用paste -d , file1.csv file2.csv

dog,001a
cats,002a
mouse,003c

但我想要这个输出

TEXT1-dog-TEXT2-001a-TEXT3
TEXT1-cats-TEXT2-002a-TEXT3
TEXT1-mouse-TEXT2-003c-TEXT3

有没有办法将多个 .csv 文件与每行之前、之间和之后的额外文本放在一起?

bash
  • 1 个回答
  • 31 Views
Martin Hope
R 9000
Asked: 2023-01-29 16:54:53 +0800 CST

将两个文件的值相乘 - 但保留小数位

  • 5

我有file1.txt

0.1234
0.333
0.22
0.1

和file2.txt

2
10
100
100

我正在寻找一个命令,该命令将行彼此相乘并输出与 file1.txt 在此位置/行中一样多的小数位。 输出.txt

0.2468
3.330
22.00
10.0

到目前为止我使用这个命令: paste file1.txt file2.txt | awk '{printf "%.4f", ($1 * $2)}' > output.txt 但是当然“%.4f”总是产生 4 位小数......

shell-script
  • 3 个回答
  • 88 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve