PureBasic
PureBasic
CSV Append a Column with Values
See more CSV Examples
Append an additional column and initialize with a value.Chilkat PureBasic Downloads
IncludeFile "CkStringBuilder.pb"
IncludeFile "CkCsv.pb"
Procedure ChilkatExample()
success.i = 0
; First initialize the CSV with content.
; permalink,company,numEmps,category,city,state,fundedDate,raisedAmt,raisedCurrency,round
; lifelock,LifeLock,,web,Tempe,AZ,1-May-07,6850000,USD,b
; mycityfaces,MyCityFaces,7,web,Scottsdale,AZ,1-Jan-08,50000,USD,seed
; flypaper,Flypaper,,web,Phoenix,AZ,1-Feb-08,3000000,USD,a
; infusionsoft,Infusionsoft,105,software,Gilbert,AZ,1-Oct-07,9000000,USD,a
; gauto,gAuto,4,web,Scottsdale,AZ,1-Jan-08,250000,USD,seed
bCrlf.i = 1
sb.i = CkStringBuilder::ckCreate()
If sb.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkStringBuilder::ckAppendLine(sb,"permalink,company,numEmps,category,city,state,fundedDate,raisedAmt,raisedCurrency,round",bCrlf)
CkStringBuilder::ckAppendLine(sb,"lifelock,LifeLock,,web,Tempe,AZ,1-May-07,6850000,USD,b",bCrlf)
CkStringBuilder::ckAppendLine(sb,"mycityfaces,MyCityFaces,7,web,Scottsdale,AZ,1-Jan-08,50000,USD,seed",bCrlf)
CkStringBuilder::ckAppendLine(sb,"flypaper,Flypaper,,web,Phoenix,AZ,1-Feb-08,3000000,USD,a",bCrlf)
CkStringBuilder::ckAppendLine(sb,"infusionsoft,Infusionsoft,105,software,Gilbert,AZ,1-Oct-07,9000000,USD,a",bCrlf)
CkStringBuilder::ckAppendLine(sb,"gauto,gAuto,4,web,Scottsdale,AZ,1-Jan-08,250000,USD,seed",bCrlf)
csv.i = CkCsv::ckCreate()
If csv.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
CkCsv::setCkHasColumnNames(csv, 1)
success = CkCsv::ckLoadFromString(csv,CkStringBuilder::ckGetAsString(sb))
; Show the initial CSV:
Debug CkCsv::ckSaveToString(csv)
Debug "----"
; Now let's add a new rightmost column.
numColumns.i = CkCsv::ckNumColumns(csv)
numRows.i = CkCsv::ckNumRows(csv)
; Set the column name.
columnIdx.i = numColumns
CkCsv::ckSetColumnName(csv,columnIdx,"new_column")
; Add the column to each row.
i.i = 0
While i < numRows
CkCsv::ckSetCell(csv,i,columnIdx,"newData")
i = i + 1
Wend
; Show the updated CSV:
Debug CkCsv::ckSaveToString(csv)
CkStringBuilder::ckDispose(sb)
CkCsv::ckDispose(csv)
ProcedureReturn
EndProcedure