`encoding/csv`를 사용하여 CSV 파일에 따옴표 붙은 문자열을 쓸 때 Go 코드에서 추가 따옴표가 생성되는 이유는 무엇입니까?
Go의 인코딩/CSV를 사용한 인용 문자열에 대한 이상한 CSV 결과
이 코드 조각의 목표는 데이터를 CSV 파일에 기록하여 인용 문자열이 데이터가 올바르게 이스케이프되었습니다. 그러나 결과 CSV에는 추가 따옴표가 포함되어 있어 불일치가 발생합니다.
<code class="go">package main import ( "encoding/csv" "fmt" "log" "os" ) func main() { f, err := os.Create("test.csv") if err != nil { log.Fatal(err) } defer f.Close() w := csv.NewWriter(f) record := []string{"Unquoted string", "Cr@zy text with , and \ and \" etc"} w.Write(record) record = []string{"Quoted string", fmt.Sprintf("%q", "Cr@zy text with , and \ and \" etc")} w.Write(record) w.Flush() }</code>
따옴표 붙은 문자열의 예상 출력은 다음과 같습니다.
[Unquoted string Cr@zy text with , and \ and " etc] [Quoted string "Cr@zy text with , and \ and \" etc"]
그러나 실제 출력에는 추가 따옴표가 포함되어 있습니다.
Unquoted string,"Cr@zy text with , and \ and "" etc" Quoted string,"""Cr@zy text with , and \ and \"" etc"""
추가 따옴표 이해
따옴표 붙은 문자열의 추가 따옴표는 큰 따옴표를 두 개의 큰 따옴표로 이스케이프해야 하는 CSV 표준을 따른 결과입니다. 인용 부호. 이는 데이터 내의 실제 큰따옴표와 레코드 구분에 사용된 큰따옴표를 구별하는 데 필요합니다.
해결책
코드는 큰따옴표 탈출에 대해 걱정할 필요가 없습니다. CSV 리더는 자동으로 이스케이프를 해제합니다. 따라서 해결책은 인용된 문자열을 작성할 때 여분의 큰따옴표를 제거하는 것입니다.
수정된 코드
<code class="go">for _, record := range [][]string{ {"Unquoted string", "Cr@zy text with , and \ and \" etc"}, {"Quoted string", "Cr@zy text with , and \ and \" etc"}, } { record[1] = fmt.Sprintf("%q", record[1][1:len(record[1])-1]) w.Write(record) }</code>
업데이트된 출력
Unquoted string,Cr@zy text with , and \ and " etc Quoted string,"Cr@zy text with , and \ and \" etc"
이번 변경으로 이제 따옴표 붙은 문자열이 올바르게 이스케이프되고 추가 따옴표가 제거됩니다.
위 내용은 `encoding/csv`를 사용하여 CSV 파일에 따옴표 붙은 문자열을 쓸 때 Go 코드에서 추가 따옴표가 생성되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

GO 프로그래밍에서 오류를 효과적으로 관리하는 방법은 다음과 같습니다. 1) 예외 대신 오류 값 사용, 2) 오류 랩핑 기술 사용, 3) 사용자 지정 오류 유형 정의, 4) 성능에 대한 오류 값 재사용, 5) 경고와 함께 공황 및 복구 사용, 6) 오류 처리 전략을 기록하고, 오류 처리, 8) 오류를 사용하여 오류가 발생합니다. 이러한 관행과 패턴은보다 강력하고 유지 관리 가능하며 효율적인 코드를 작성하는 데 도움이됩니다.

GOROONE 및 채널을 사용하여 동시성을 구현할 수 있습니다. 1) Goroutines를 사용하여 예를 들어 음악을 즐기고 친구를 동시에 관찰하는 등의 작업을 병렬로 수행하십시오. 2) 생산자 및 소비자 모델과 같은 채널을 통해 고 루틴간에 데이터를 안전하게 전송합니다. 3) Goroutines와 교착 상태의 과도한 사용을 피하고 동시 프로그램을 최적화하기 위해 시스템을 합리적으로 설계하십시오.

GOOFFERSMULTIPLEAPLEACHELINDINGCURRENTDATDATDATDATRUCTRUCES (MUTEXES, 채널, 및 및 원자가 포함

go'serrorhandlingsexplicit, treatingerrorserSreturnEdValuesratherthanexceptions, 1) Go'sportroachensureserorawarensessbutcanleadtoverbosecode.2) pythonandjavauseexeceptionsforcleanercodebutmiserrors.3) go'smethodoTodoTand

WhentestinggocodewithInitFunctions, useExplicitSetUpFunctionsOrsParateTestOvoiddenceNInItfictionSideffects.1) useExplicitSetUpFunctoControlGlobalVariableInitialization.2) CreateSeparateTesteSpilestobySinitFunctions 및 testesten

go'serrorhandlingreturnserrorsvalues whithuseexceptions와 달리 1) Go'sMethodensuresexpliciterRorhandling, promotingrobustcodebutincreasingverbosity.2) Javaandthon'sexextionslowercodebutcodebutcodebutcanlederforlortorifneterfortorifneteriflerortorifnetrorirederiflofertorifneateRoferfortoriflogertoflortoflerortofneateRofer

AneffectiveInterfaceingoisminimal, Clear, and Promotesloosecoupling.1) Minimizetheinterfaceforflexibilityandeasofimplementation.2) usicfacesforabStractionToswapimementationswhangingCallingCode.3) DesignStabilitySUsingInterfacestomockDep

중앙 집중식 오류 처리는 GO 언어에서 코드의 가독성과 유지 가능성을 향상시킬 수 있습니다. 구현 방법 및 장점에는 다음이 포함됩니다. 1. 비즈니스 로직에서 별도의 오류 처리 로직 및 코드를 단순화합니다. 2. 중앙 처리로 오류 처리의 일관성을 확인하십시오. 3. 연기 및 복구를 사용하여 공황을 포착하고 처리하여 프로그램 견고성을 향상시킵니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)