TStringList的分隔符應用

2021-04-12 21:28:13 字數 2680 閱讀 3920

tstrings是乙個抽象類,在實際開發中,是除了基本型別外,應用得最多的。

常規的用法大家都知道,現在來討論它的一些高階的用法。

先把要討論的幾個屬性列出來:

1、commatext

2、delimiter & delimitedtext

3、names & values & valuefromindex

先看第乙個:commatext。怎麼用呢?用**說話:

const

constr :string = 'aaa,bbb,ccc,ddd';

varstrs :tstrings;

i :integer;

begin

strs := tstringlist.create;

strs.commatext := constr;

for i := 0 to strs.count-1 do

showmessage(strs[i]);

end;

執行了這段**後,可以看到showmessage顯示出來的分別是:aaa bbb ccc ddd。

也就是說,strs.commatext := constr這一句的作用,就是把乙個字串以','為分割符,分段新增到tstrings中。

那麼如果不是以','來分割,又該怎麼做呢?現在看第二個例子。使用delimiter和delimitedtext。

const

constr :string = 'aaa/bbb/ccc/ddd';

varstrs :tstrings;

i :integer;

begin

strs := tstringlist.create;

strs.delimiter := '/';

strs.delimitedtext := constr;

for i := 0 to strs.count-1 do

showmessage(strs[i]);

end;

可以看到, 顯示的效果和第乙個例子是一模一樣的。解釋一下:

delimiter為分隔符,預設為:','。delimitedtext就是按delimiter為分隔符的乙個串,得到賦值後回把這個字串按delimiter的字元新增到tstrings中。

說到這裡,有想起乙個屬性,quotechar。其預設值為:'"'(不包括單引號)

有何用呢?看例子:

const

constr :string = '"aaa"/"bbb"/"ccc"/"ddd"';

varstrs :tstrings;

i :integer;

begin

strs := tstringlist.create;

strs.delimiter := '/';

strs.delimitedtext := constr;

for i := 0 to strs.count-1 do

showmessage(strs[i]);

end;

顯示出來的仍然是aaa bbb ccc ddd。為什麼不是:"aaa" "bbb" "ccc" "ddd"呢?

再來看乙個例子:

const

constr :string = '|aaa|/|bbb|/|ccc|/|ddd|';

varstrs :tstrings;

i :integer;

begin

strs :=tstringlist.create;

strs.delimiter := '/';

strs.quotechar := '|';

strs.delimitedtext := constr;

for i := 0 to strs.count-1 do

showmessage(strs[i]);

end;

顯示出來的又是aaa bbb ccc ddd。對比一下,應該不難明白吧?這個就不多說了,用得也不多。

但是還要多說一句,當delimiter為:','而quotechar為:'"'時,delimitedtext和commatext是同等的。

最後要說的三個是:names & values & valuefromindex。

看看下面的**:

const

constr :string = '0=aaa,1=bbb,2=ccc,3=ddd';

varstrs :tstrings;

i :integer;

begin

strs := tstringlist.create;

strs.commatext := constr;

for i := 0 to strs.count-1 do

begin

showmessage(strs.names[i]);

showmessage(strs.values[strs.names[i]]);

showmessage(strs.valuefromindex[i]);

end;

end;

通過這個例子不難看出:

這個時候strs中的內容是:

0=aaa

1=bbb

2=ccc

3=ddd

而names中則是: 0

1 23

在values中則是:

aaabbb

cccddd  

Hive的列分隔符和行分隔符

在建立hive表時,預設行分隔符 a 列分隔符 n 這兩項也是可以設定的。在實際開發中,一般預設使用預設的分隔符,當然有些場景下也會自定義分隔符。spark hive use test db 建立外部表 create external table test tb user id bigint com...

hive的列分隔符和行分隔符的使用

目錄 一 hive中預設的分割符如下 二 分隔符的指定與使用 三 建好表之後更改字段分隔符 分隔符描述 n 行分隔符 a欄位分隔符 001 barray struct的元素間的分隔符,map的鍵值對與鍵值對間分隔符 002 cmap中鍵與值之間的 分隔符 003 hive中在建立表時,一般會根據匯入...

awk linux 分隔 awk多分隔符

awk的 f引數可以指定新的分隔符,有些時候可能需求指定多個分隔符,比如下面的內容 root n1 netstat an grep estab udp 0 0 192.168.1.120 35570 212.47.249.141 123 established udp 0 0 192.168.1.1...