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...