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
    • 最新
    • 标签
主页 / coding / 问题 / 76946539
Accepted
João Pedro Schmitt
João Pedro Schmitt
Asked: 2023-08-21 23:00:09 +0800 CST2023-08-21 23:00:09 +0800 CST 2023-08-21 23:00:09 +0800 CST

如何使用 terraform csvdecode 读取双引号字符串值?

  • 772

我有一个 CSV 文件,其中包含以下内容:

id,value
123,{"M":{"name_1":{"S":"value_1"}, "name_2":{"S":"value_2"}}}

我正在尝试读取此 CSV 文件并通过以下方式在 DynamoDB 中创建记录:

locals {
  custom_data = csvdecode(file("${path.module}/../custom_data.csv"))
}

resource "aws_dynamodb_table_item" "custom_table_item" {
  for_each = {for row in local.custom_data : row.id => row}

  table_name = aws_dynamodb_table.custom_table.name
  hash_key   = aws_dynamodb_table.custom_table.hash_key

  item = jsonencode({
    "id" : { "S" : each.value.id },
    "value" : jsondecode(each.value.value)
  })

  lifecycle {
    ignore_changes = [item]
  }
}

但是,此代码不起作用,并且我找不到任何有关如何以可以创建jsondecode适当的 JSON 结构的方式从 CSV 文件中读取双引号值的示例。有谁知道这是怎么做到的吗?

csv
  • 2 2 个回答
  • 18 Views

2 个回答

  • Voted
  1. Best Answer
    Paolo
    2023-08-21T23:21:28+08:002023-08-21T23:21:28+08:00

    清理您的 csv 文件:

    id,value
    123,"{""M"":{""name_1"":{""S"":""value_1""}, ""name_2"":{""S"":""value_2""}}}"
    

    然后:

    $ terraform-repl
    > csvdecode(file("${path.module}/custom_data.csv"))
    tolist([
      {
        "id" = "123"
        "value" = "{\"M\":{\"name_1\":{\"S\":\"value_1\"}, \"name_2\":{\"S\":\"value_2\"}}}"
      },
    ])
    
    > jsondecode(csvdecode(file("${path.module}/custom_data.csv"))[0].value)
    {
      "M" = {
        "name_1" = {
          "S" = "value_1"
        }
        "name_2" = {
          "S" = "value_2"
        }
      }
    }
    
    • 2
  2. Martin Atkins
    2023-08-21T23:52:18+08:002023-08-21T23:52:18+08:00

    您在此处显示的文档实际上并不是 Terraform 函数要解析的通常意义上的 CSV 文档,这是RFC 4180中定义的格式。您的第二个“字段”似乎是一个 JSON 文档,内部有自己的字段(包括逗号),这意味着csvdecode会误解该文档的含义。

    相反,我认为这是一种自定义格式,因此使用更简单的原语来解析它:

    locals {
      custom_data_raw = file("${path.module}/../custom_data.csv")
      custom_data_lines = slice([
        for chunk in split("\n", local.custom_data_raw) : chomp(chunk)
      ], 1, length(local.custom_data_raw))
      custom_data_fields = [
        for line in local.custom_data_lines : regex("^(?P<id>[^,]),(?P<values>.*)$", line)
      ]
      custom_data = {
        for fields in local.custom_data_fields :
        fields.id => jsondecode(fields.value)
      }
    }
    

    上面混合使用了不同的 Terraform 函数将文件内容分割成更小的标记:

    • split将整个内容拆分为单独的行(以chomp处理 Windows 风格的行结尾的可能性,这将是\r\n而不是只是\n,因此之后需要额外的剥离。)
    • slice丢弃第一行,即“标题”行。
    • regex以忽略“值”字段中额外的逗号和引号的方式分隔“id”和“值”字段。
    • 最后jsondecode使用 JSON 语法将“values”字符串替换为它所描述的对象。

    我将其分为多个步骤,以便更轻松地查看中间步骤的结果,但如果您愿意,您应该能够将其中至少一些步骤组合成更大的表达式。

    毕竟,local.custom_data应该是一个可以与 一起使用的数据结构for_each,形状如下:

    {
      "123" = {
        "M" = {
          "name_1" = {
            "S" = "value_1"
          }
          "name_2" = {
            "S" = "value_2"
          }
        }
      }
    }
    
    resource "aws_dynamodb_table_item" "custom_table_item" {
      for_each = local.custom_data
    
      table_name = aws_dynamodb_table.custom_table.name
      hash_key   = aws_dynamodb_table.custom_table.hash_key
    
      item = jsonencode({
        "id" : { "S" : each.key },
        "value" : each.values
      })
    
      lifecycle {
        ignore_changes = [item]
      }
    }
    

    如果您确实想将其视为常规 CSV 文档并使用csvdecode,那么您需要首先更改“值”字段的编码以转义引号和逗号,这意味着:

    • 将整个 JSON 字符串写入引号中的第二个参数中",如 RFC 4180 第 2 节第 6 项中所述。
    • 在 JSON 文档中写入文字引号,通过加倍(""而不是仅仅")进行转义,如 RFC 4180 第 2 部分第 7 项中所述。

    如果原则上可以使用 Terraform 本身执行该转换,但它与我上面展示的低级解析大致相同,首先分别标记 id 和 value 字段,所以我不会采取此选项,除非我可以更改生成原始文档的任何系统以生成有效的 CSV 数据本身,以便 Terraform 可以仅依赖于csvdecode.

    • 1

相关问题

  • BAT 文件 - 根据文件内容重命名多个 .csv 文件

Sidebar

Stats

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

    使用 <font color="#xxx"> 突出显示 html 中的代码

    • 2 个回答
  • Marko Smith

    为什么在传递 {} 时重载解析更喜欢 std::nullptr_t 而不是类?

    • 1 个回答
  • Marko Smith

    您可以使用花括号初始化列表作为(默认)模板参数吗?

    • 2 个回答
  • Marko Smith

    为什么列表推导式在内部创建一个函数?

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Marko Smith

    java.lang.NoSuchMethodError: 'void org.openqa.selenium.remote.http.ClientConfig.<init>(java.net.URI, java.time.Duration, java.time.Duratio

    • 3 个回答
  • Marko Smith

    为什么 'char -> int' 是提升,而 'char -> Short' 是转换(但不是提升)?

    • 4 个回答
  • Marko Smith

    为什么库中不调用全局变量的构造函数?

    • 1 个回答
  • Marko Smith

    std::common_reference_with 在元组上的行为不一致。哪个是对的?

    • 1 个回答
  • Marko Smith

    C++17 中 std::byte 只能按位运算?

    • 1 个回答
  • Martin Hope
    fbrereto 为什么在传递 {} 时重载解析更喜欢 std::nullptr_t 而不是类? 2023-12-21 00:31:04 +0800 CST
  • Martin Hope
    比尔盖子 您可以使用花括号初始化列表作为(默认)模板参数吗? 2023-12-17 10:02:06 +0800 CST
  • Martin Hope
    Amir reza Riahi 为什么列表推导式在内部创建一个函数? 2023-11-16 20:53:19 +0800 CST
  • Martin Hope
    Michael A fmt 格式 %H:%M:%S 不带小数 2023-11-11 01:13:05 +0800 CST
  • Martin Hope
    God I Hate Python C++20 的 std::views::filter 未正确过滤视图 2023-08-27 18:40:35 +0800 CST
  • Martin Hope
    LiDa Cute 为什么 'char -> int' 是提升,而 'char -> Short' 是转换(但不是提升)? 2023-08-24 20:46:59 +0800 CST
  • Martin Hope
    jabaa 为什么库中不调用全局变量的构造函数? 2023-08-18 07:15:20 +0800 CST
  • Martin Hope
    Panagiotis Syskakis std::common_reference_with 在元组上的行为不一致。哪个是对的? 2023-08-17 21:24:06 +0800 CST
  • Martin Hope
    Alex Guteniev 为什么编译器在这里错过矢量化? 2023-08-17 18:58:07 +0800 CST
  • Martin Hope
    wimalopaan C++17 中 std::byte 只能按位运算? 2023-08-17 17:13:58 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve