Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PureBasic) CSV Special Chars - Comma, Double-QuotesThe Chilkat CSV class/component automatically handles special characters which include double-quotes, and the delimiter character (comma or semicolon). The Chilkat CSV library/component/class is freeware. The downloads for .NET, C++, Perl, Java, Ruby, and Python contain all of the Chilkat classes, some of which are freeware and some of which require licensing.
IncludeFile "CkCsv.pb" Procedure ChilkatExample() ; This example program loads a file (sample.csv) ; that contains this content: ; ; year,color,country,food ; 2001,red,France,cheese ; 2005,blue,"United States",hamburger ; 2008,green,Italy,pasta ; 1998,orange,Japan,sushi ; ; The first row contains the column names. ; This file is available at: ; http://www.chilkatsoft.com/testData/sample.csv csv.i = CkCsv::ckCreate() If csv.i = 0 Debug "Failed to create object." ProcedureReturn EndIf ; Prior to loading the CSV file, indicate that the 1st row ; should be treated as column names: CkCsv::setCkHasColumnNames(csv, 1) ; Load the CSV records from the file: success.i success = CkCsv::ckLoadFile(csv,"sample.csv") If success <> 1 Debug CkCsv::ckLastErrorText(csv) CkCsv::ckDispose(csv) ProcedureReturn EndIf ; A field may contain the delimiter character (in this case ; the delimiter is a comma): ; Change "cheese" to "cheese,baguette" ; ("cheese" is at row=0, column=3 success = CkCsv::ckSetCell(csv,0,3,"cheese,baguette") ; A field may also contain double-quotes: ; Change blue to shiny "metallic" blue success = CkCsv::ckSetCell(csv,1,1,"shiny " + Chr(34) + "metallic" + Chr(34) + " blue") ; Write the updated CSV to a string and display: csvDoc.s csvDoc = CkCsv::ckSaveToString(csv) Debug csvDoc ; Save the CSV to a file: success = CkCsv::ckSaveFile(csv,"out.csv") If success <> 1 Debug CkCsv::ckLastErrorText(csv) EndIf ; The out.csv contains this: ; year,color,country,food ; 2001,red,France,"cheese,baguette" ; 2005,"shiny ""metallic"" blue","United States",hamburger ; 2008,green,Italy,pasta ; 1998,orange,Japan,sush CkCsv::ckDispose(csv) ProcedureReturn EndProcedure |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.