作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试解析包含德语文本的 CSV 文件,即它不是以“逗号”分隔,而是以分号分隔,并且可能包含变音符号(äöü 等)。
使用 Cassava并关注链接 tutorial ,对于标题包含元音变音的列,我收到错误:
parse error (Failed reading: conversion error: no field named "W\228hrung") at "\nEUR;0,99"
MRE:
{-# LANGUAGE OverloadedStrings, TypeApplications #-}
import Data.Char
import qualified Data.ByteString.Lazy as ByteString
import Data.Csv
import Data.Text
myOpts = defaultDecodeOptions {
decDelimiter = fromIntegral (ord ';')
}
data Transaction = Tx
{ waehrung :: Text
, betrag :: Text
} deriving Show
instance FromNamedRecord Transaction where
parseNamedRecord m =
Tx
<$> m .: "Währung"
<*> m .: "Betrag"
main :: IO ()
main =
ByteString.readFile "bank.csv"
>>= print . decodeByNameWith @Transaction myOpts
将其保存为 bank.csv
:
Währung;Betrag
EUR;14,12
EUR;0,99
版本:GHC 8.10.7木薯^>=0.5.2.0
最佳答案
你需要写:
import qualified Data.Text.Encoding as Text
instance FromNamedRecord Transaction where
parseNamedRecord m =
Tx
<$> m .: Text.encodeUtf8 "Währung"
<*> m .: "Betrag"
问题是 cassava
在内部将字段名称表示为文本的 UTF-8 编码的 ByteString
。但是,用于将字符串文字编码为 ByteString
的 ByteString
的 IsString
实例不使用UTF-8 编码,而是将每个字符编码为其代码点的最低有效字节(这基本上从不您想要的非 ASCII 字符串)。
关于csv - 木薯无法识别带有变音符号的命名字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70645130/
我是一名优秀的程序员,十分优秀!