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
    • 最新
    • 标签
主页 / unix / 问题 / 778203
Accepted
baiserekku
baiserekku
Asked: 2024-06-12 18:07:14 +0800 CST2024-06-12 18:07:14 +0800 CST 2024-06-12 18:07:14 +0800 CST

根据用户输入打印 csv 列

  • 772

我有一个.csv包含以下格式的多行文件:

¬Country¬,¬Year¬,¬Singer¬,¬Song Title¬
¬Japan¬,¬1999¬,¬Utada Hikaru¬,¬First Love¬
¬South Korea¬,¬1999¬,¬Lee Jung Hyun¬,¬Wa¬
...

我可以用 打印我想要的信息awk。例如

awk -F'¬' '{print $2" - "$4}' Model.csv | tail -n +2

这将导致:

Japan - 1999
South Korea - 1999

我希望这基于 Bash 脚本中的用户输入,用户可以选择要打印哪些列以及以哪种“格式”打印。例如,如果我希望输出为

[1999] Utada Hikaru - First Love
[1999] Lee Jung Hyun - Wa

我会用

awk -F'¬' '{print "["$4"]" " "$6" - "$8}' Model.csv | tail -n +2

但是,通过使用"["$4"]" " "$6" - "$8作为输入,awk 不会将其读取为打印命令的模式

 #!/bin/bash
 read -p "Which format? " format
 #User will type here desired print pattern, for example "["$4"]" " "$6" - "$8
 awk -v "var=$format" -F'¬' '{print var}' Model.csv

导致

"["$4"]" " "$6" - "$8
"["$4"]" " "$6" - "$8
text-processing
  • 1 1 个回答
  • 75 Views

1 个回答

  • Voted
  1. Best Answer
    Ed Morton
    2024-06-12T22:45:04+08:002024-06-12T22:45:04+08:00

    从示例输入来看,您的字段分隔符实际上是,,而不是¬,并且这些字符的使用方式与符合标准的 CSV 中的¬双引号 () 的使用方式相同(请参阅使用 awk 高效解析 csv 的最可靠方法)。"

    假设情况确实如此,这将在任何 POSIX awk 中执行您想要的操作:

    $ cat tst.sh
    #!/usr/bin/env bash
    
    read -p "Which format? " format
    
    awk -F'¬,¬' '
        NR > 1 {
            gsub(/^¬|¬$/,"")
            print '"$format"'
        }
    ' "${@:--}"
    

    并调整字段编号以将输入视为 CSV:

    $ ./tst.sh Model.csv
    Which format? "["$2"]" " "$3" - "$4
    [1999] Utada Hikaru - First Love
    [1999] Lee Jung Hyun - Wa
    

    我假设¬换行符不能出现在你的 CSV 字段内。

    警告:请注意,format在 awk 看到它之前,shell 变量正在扩展成为 awk 脚本主体的一部分,因此您必须非常小心允许谁使用该脚本,并确保他们完全理解 awk 语法,除了可能出现的神秘错误之外:

    $ ./tst.sh Mode1.csv
    Which format? $#
    awk: cmd. line:5:       print $#
    awk: cmd. line:5:              ^ syntax error
    
    $ ./tst.sh Mode1.csv
    Which format? $1 / $4
    awk: cmd. line:4: (FILENAME=Mode1.csv FNR=1) fatal: division by zero attempted
    

    这会导致代码注入漏洞:

    $ ./tst.sh Mode1.csv
    Which format? system("echo hello")
    hello
    0
    

    就我个人而言,我根本不会这样做,而是想出其他界面让用户选择要打印的字段并设置打印格式。

    • 3

相关问题

  • grep 从 $START 到 $END 的一组行并且在 $MIDDLE 中包含匹配项

  • 重新排列字母并比较两个单词

  • 在awk中的两行之间减去相同的列

  • 多行文件洗牌

  • 如何更改字符大小写(从小到大,反之亦然)?同时[重复]

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