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
    • 最新
    • 标签
主页 / computer / 问题 / 1564877
Accepted
Christian Hick
Christian Hick
Asked: 2020-06-30 15:23:15 +0800 CST2020-06-30 15:23:15 +0800 CST 2020-06-30 15:23:15 +0800 CST

附加到不同文件时,带有逗号分隔值的 Bash 脚本变量不是逗号分隔的

  • 772

我有一个验证表条目的 bash 脚本。最终输出值是 $out,它被插入到 SQL INSERT 语句中,然后附加到 /tmp/crew.txt。虽然 $out 显然是用逗号分隔的,但 /tmp/crew.txt 中生成的 INSERT 语句中的值之间没有逗号。为什么会出现这种情况以及如何解决它,以便我在 /tmp/crew.txt 中有逗号分隔值?

#!/bin/bash

out=290,'02:20:00','02:40:00',20.5,NULL

echo "${out:1}"

290,'02:20:00','02:40:00',20.5,NULL


echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES ("${out:1}");" >> /tmp/crew.txt
vi /tmp/crew.txt

INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES ( 290 '02:20:00' '02:40:00' 20 NULL);

因此 /tmp/crew.txt 中的结果应该是:

INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES ( 290,'02:20:00','02:40:00',20,NULL);
bash script
  • 3 3 个回答
  • 1603 Views

3 个回答

  • Voted
  1. DavidPostill
    2020-06-30T15:52:30+08:002020-06-30T15:52:30+08:00

    为什么会这样,如何解决

    从脚本中删除回显的输出和空行会得到以下清理脚本:

    #!/bin/bash
    out=290,'02:20:00','02:40:00',20.5,NULL
    echo "${out:1}"
    echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES ("${out:1}");" >> /tmp/crew.txt
    

    通过ShellCheck运行该脚本– shell 脚本分析工具会产生以下错误:

    $ shellcheck myscript
     
    Line 4:
    echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES ("${out:1}");" >> /tmp/crew.txt
    >>                                                                                      ^-- SC2027: The surrounding quotes actually unquote this. Remove or escape them.
    
    $ 
    

    按照建议删除引号可修复该错误,所以现在我们有:

    #!/bin/bash
    out=290,'02:20:00','02:40:00',20.5,NULL
    echo "${out:1}"
    echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES (${out:1});" >> /tmp/crew.txt
    

    但是运行它仍然不能给出正确的答案,因为echo "${out:1}"单引号'没有存储在 中out,它们需要被转义:

    $ test.sh
    90,02:20:00,02:40:00,20.5,NULL
    $
    

    解决这个问题:

    #!/bin/bash
    out=290,\'02:20:00\',\'02:40:00\',20.5,NULL
    echo "${out:1}"
    echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES (${out:1});" >> test.txt
    

    注意我已将输出文件名更改为test.txt

    测试:

    $ test.sh
    90,'02:20:00','02:40:00',20.5,NULL
    $ cat test.txt
    INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES (90,'02:20:00','02:40:00',20.5,NULL);
    $
    

    所以你的脚本的最终固定版本是:

    #!/bin/bash
    out=290,\'02:20:00\',\'02:40:00\',20.5,NULL
    echo "${out:1}"
    echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES (${out:1});" >> >> /tmp/crew.txt
    

    关于调试损坏的脚本的课程到此结束。

    • 4
  2. Best Answer
    Kamil Maciorowski
    2020-06-30T19:22:01+08:002020-06-30T19:22:01+08:00

    假设:您的IFS变量包含,. 该脚本不会更改IFS,因此非默认值必须已在环境中。

    This other answer注意到您${out:1}在如下所示的行中未引用:

    echo "foo"${out:1}"bar"
    

    未加引号的变量会进行分词和文件名生成。分词是 by IFS。未引用${out:1}的被拆分为多个单词,echo获取多个参数并打印它们,并用单个空格分隔(因为这是什么echo,不管IFS)。

    如果您printf 按照建议使用,则更容易判断变量是否被引用:

    printf 'INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES (%s);\n' "${out:1}"
    

    如果你没有双引号这个变量,printf会得到多个参数${out:1},它会生成多行。然后应该很明显会发生一些分裂。使用echo它连接它的论点在某种程度上混淆了这个事实。


    单独的问题:

    • 所需的输出表明您不想要"${out:1}"但" $out"带有前导空格。

    • 要在变量中包含单引号,您应该确保 shell 不会删除它们。转义它们(归功于已经提到的答案)或双引号:

      out="290,'02:20:00','02:40:00',20.5,NULL"
      
    • 3
  3. Christian Hick
    2020-06-30T16:15:42+08:002020-06-30T16:15:42+08:00

    对我有用的解决方案是回显以下 INSERT 语句:

    echo "INSERT INTO tip_run (date_linkid, start_time, finish_time, weight, note) VALUES (${out:1});" >> /tmp/crew.txt
    

    无需逃避。但是不确定原因。

    • 0

相关问题

  • 在非 root 用户上用 bash 替换 zsh

  • 在 macOS High Sierra 的终端中设置环境变量时遇到问题

  • 对于 cp 或 mv,是否有等同于 cd - 的东西?

  • Notify-发送窗口下出现的通知

  • 如何从 WSL 打开 office 文件

Sidebar

Stats

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

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 为什么通过电缆(同轴电缆)的千兆位/秒 Internet 连接不能像光纤一样提供对称速度? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    fixer1234 “HTTPS Everywhere”仍然相关吗? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve