主頁 > 移動端開發 > 第四十九章 Caché 函式大全 $PIECE 函式

第四十九章 Caché 函式大全 $PIECE 函式

2020-10-11 19:41:01 移動端開發

文章目錄

  • 第四十九章 Caché 函式大全 $PIECE 函式
  • 大綱
    • 引數
  • 描述
    • 回傳一個子字串,
  • 引數
    • string
    • delimiter
    • from
    • to
    • 指定`* -n`和`* + n`引數值
    • 示例:回傳帶分隔符的子字串
  • 使用SET $PIECE替換子字串
    • 示例:替換分隔的子字串
    • 初始化字串變數
    • 分隔符為空字串
    • 引數超過32,768個字符的$PIECE
  • 注意
    • 使用`$PIECE`解包資料值
    • $PIECE 與 $LENGTH
    • Null Values
    • 強制數值計算
    • 嵌套$PIECE操作
    • `$PIECE`與`$EXTRACT`和`$LIST`的比較

第四十九章 Caché 函式大全 $PIECE 函式

使用定界符回傳或替換子字串,

大綱

$PIECE(string,delimiter,from,to)
$P(string,delimiter,from,to)

SET $PIECE(string,delimiter,from,to)=value
SET $P(string,delimiter,from,to)=value

引數

  • string 標識分隔的子字串的目標字串,將字串指定為計算結果為帶引號的字串或數字值的運算式,在SET $PIECE語法中,字串必須是變數或多維屬性,
  • 用于標識字串中子字串的定界符,將定界符指定為一個運算式,該運算式的結果為包含一個或多個字符的帶引號的字串,
  • from 可選-運算式的計算結果為指定字串中子字串的位置或子字串范圍的開頭的代碼,子字串由定界符分隔,并從1開始計數,允許的值為n(正整數,指定從字串開頭的子字串計數),*(指定字串中的最后一個子字串)和* -n(偏移整數計數),從字串末尾開始倒數的子字串), SET $PIECE語法還支持* + n(要追加到字串末尾的子字串的偏移整數計數),因此,第一個定界子串是1,第二個定界子串是2,最后一個定界子串是*,倒數第二個定界子串是* -1,如果忽略from,則默認為第一個帶分隔符的子字串,
  • to 可選—一個運算式,其計算結果為指定字串中一系列子字串的結尾子字串的代碼,必須與from一起使用,允許的值為n(從字串開頭指定子字串計數的正整數),*(指定字串中最后一個子字串)和* -n(從字串末尾偏移的子字串整數), SET $PIECE語法還支持* + n(用于附加到字串末尾的一系列子字串的偏移整數),如果to在字串中位于from之前,則不執行任何操作,也不產生錯誤,

描述

$PIECE通過分隔符的存在來標識字串中的子字串,如果分隔符未出現在字串中,則整個字串將被視為單個子字串,

$PIECE可以通過兩種方式使用:

  • 從字串回傳子字串,這使用$PIECE(string,delimiter,from,to)語法,
  • 替換字串中的子字串,它標識一個子字串并將其替換為另一個子字串,替換子字串的長度可以與原始子字串相同,更長或更短,這使用$PIECE(string,delimiter,from,to) = value 語法,

注意:$PIECE是用于處理包含定界子字串的字串的通用函式,若要處理包含特定MultiValue定界符的MultiValue動態陣列字串,請使用$MV函式,

回傳一個子字串,

從字串回傳指定的子字串(片斷)時,回傳的子字串取決于所使用的引數:

  • $PIECE(string,delimiter)回傳字串中的第一個子字串,如果定界符出現在字串中,則這是第一次出現定界符之前的子字串,如果字串中未出現定界符,則回傳的子字串為字串,
  • $PIECE(string,delimiter,from)回傳一個子字串,其位置由from引數指定,子字串由定界符以及字串的開頭和結尾定界,分隔符本身不回傳,
  • $PIECE(string,delimiter,from,to)回傳一系列子字串,包括從中指定的子字串到in至(包括)中指定的子字串, $PIECE的這種四引數形式回傳一個子字串,該子字串包括在from和to子字串之間出現的定界符的任何中間出現,如果to大于子字串的數量,則回傳的子字串將包括字串末尾的所有子字串,

引數

string

當使用$PIECE回傳子字串時,string可以是用引號引起來的字串文字,規范數字,變數,物件屬性或任何求值為字串或數字的有效ObjectScript運算式,如果將空字串(“”)指定為目標字串,則$PIECE始侄訓傳該空字串,而不考慮其他引數值,

目標字串通常包含用作分隔符的字符(或字串)實體,此字符或字串也不能用作字串中的資料值,

$PIECE與等號左側的SET一起使用以替換子字串時,string可以是變數或多維屬性參考,它不能是非多維物件屬性,

delimiter

用于在字串中定界子字串的搜索字串,它可以是用引號引起來的字串文字,規范的數字,變數或任何有效的ObjectScript運算式(其結果為字串或數字),

通常,定界符是一個指定字符,從不用作字串中的資料,而是專門留出用作分隔子字串的定界符,例如,如果定界符為“^”,則字串“Red^Orange^Yellow”包含三個定界子字串,

分隔符可以是多字符字串,可以在字串資料中使用其各個字符,例如,如果定界符為“^#”,則字串“Red^Orange^#^Yellow#Green#^Blue”包含兩個定界子字串:“Red^Orange”“^Yellow#Green#^Blue”

通常,字串不以定界符開頭或結尾,如果字串以分隔符開始或結束,則$PIECE將此分隔符視為使用空字串(“”)值劃分子字串,例如,如果定界符為“^”,則字串“^Red^Orange^Yellow^” 包含五個定界子字串;子字串1和5具有空字串值,

如果指定的定界符不在字串中,則$PIECE回傳整個字串,如果指定的分隔符是空字串(“”),則$PIECE回傳空字串,

from

子字串在字串中的位置,使用n(正整數)從字串開頭算起定界的子字串,使用*指定字串中最后一個定界的子字串,使用* -n通過與字串中最后一個分隔的子字串的偏移量來計數分隔的子字串,

  • 1指定字串的第一個子字串(在第一次出現定界符之前的子字串),如果string不包含指定的分隔符,則from值1將回傳string,如果忽略from,則默認為1,
  • 2指定字串的第二個子字串(出現在分隔符的第一次和第二次出現之間,或第一次出現的分隔符和字串結尾之間的子字串),
  • *指定字串的最后一個子字串(最后一次出現定界符之后的子字串),如果string不包含指定的分隔符,則from值*會回傳string,
  • *-1指定字串的倒數第二個子字串, * -n通過相對于字串最后一個子字串的偏移量進行計數, * -0是字串的最后一個子字串; ** -0在功能上相同,
  • 僅適用于SET $PIECE語法— * + n(星號后跟一個正數)將定界的子字串附加偏移量,超出字串末尾,因此,* + 1在字串末尾附加一個帶分隔符的子字串,* + 2在字串末尾兩個位置附加一個分隔的子字串,并用定界符填充,
  • 如果from是空字串(“”),零,負數,或者指定了超出字串中子字串數量的計數或偏移量,則$PIECE回傳空字串,

$PIECE將a從數字形式轉換為規范形式(決議前導正負號并洗掉前導零),然后將其截斷為整數,

如果from引數與to引數一起使用,則它將標識要作為字串回傳的子字串范圍的開始,并且應小于to的值,

to

字串中子字串的編號,該字串終止由from引數啟動的范圍,回傳的字串包括from和to子字串,以及任何中間子字串和分隔它們的定界符, to引數必須與from一起使用,并且應大于from的值,

使用n(正整數)從字串開頭算起定界的子字串,使用*指定字串中最后一個定界的子字串,使用* -n通過從字串中最后一個帶分隔符的子字串向后偏移來計數帶分隔符的子字串,

僅對于SET $PIECE語法-* + n(星號后跟一個正數)指定要附加到字串末尾之外的子字串范圍的末尾,

  • 如果from小于to,則$PIECE回傳一個字串,該字串包括此范圍內的所有帶分隔符的子字串,包括from和to子字串,回傳的字串包含此范圍內的子字串和定界符,如果to大于分隔的子字串的數量,則回傳的字串包含從from子字串開始,一直到字串末尾的所有字串資料(子字串和定界符),
  • 如果from等于to,則$PIECE回傳from子字串,如果from和to是相同的值,或者是參考相同子字串的不同值,則可能發生這種情況,
  • 如果from大于to,為零(0),或者為空字串(“”),則$PIECE回傳一個空字串,

$PIECE將a轉換為標準格式(決議前導正負號并洗掉前導零),然后將其截斷為整數,

指定* -n* + n引數值

使用變數指定* -n* + n時,必須始終在引數本身中指定星號和符號字符,

以下是* -n的有效規格:

/// d ##class(PHA.TEST.Function).PIECE()
ClassMethod PIECE()
{
	SET count=2
	SET alph="a^b^c^d"
	WRITE $PIECE(alph,"^",*-count)
}

DHC-APP>d ##class(PHA.TEST.Function).PIECE()
b
/// d ##class(PHA.TEST.Function).PIECE1()
ClassMethod PIECE1()
{
	SET count=-2
	SET alph="a^b^c^d"
	WRITE $PIECE(alph,"^",*+count)
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE1()
b

以下是* + n的有效規范:

/// d ##class(PHA.TEST.Function).PIECE2()
ClassMethod PIECE2()
{
	SET count=2
	SET alph="a^b^c^d"
	SET $PIECE(alph,"^",*+count)="F"
	WRITE alph
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE2()
a^b^c^d^^F

這些引數值內允許使用空格,

示例:回傳帶分隔符的子字串

在下面的示例中,每個$PIECE回傳指定的子字串,該子字串由“,”定界符標識:

/// d ##class(PHA.TEST.Function).PIECE3()
ClassMethod PIECE3()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	WRITE $PIECE(colorlist,","),!     ; returns "Red" (substring 1) by default
	WRITE $PIECE(colorlist,",",3),!   ; returns "Blue" the third substring
	WRITE $PIECE(colorlist,",",*),!   ; returns "Black" the last substring
	WRITE $PIECE(colorlist,",",*-1),! ; returns "Orange" the next-to-last substring
}

DHC-APP>d ##class(PHA.TEST.Function).PIECE3()
Red
Blue
Black
Orange

在下面的示例中,$PIECE回傳數字的整數和小數部分:

/// d ##class(PHA.TEST.Function).PIECE4()
ClassMethod PIECE4()
{
	SET int=$PIECE(123.999,".")
	SET frac=$PIECE(123.999,".",*)
	WRITE "integer=",int," fraction =.",frac
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE4()
integer=123 fraction =.999

下面的示例回傳“Blue,Yellow,Orange”,即顏色串列中的第三到第五個子字串,用“,”分隔:

/// d ##class(PHA.TEST.Function).PIECE5()
ClassMethod PIECE5()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	SET extract=$PIECE(colorlist,",",3,5)
	WRITE extract
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE5()
Blue,Yellow,Orange

以下WRITE陳述句均回傳第一個子字串“123”,表明當from的值等于1時,這些格式是等效的:

/// d ##class(PHA.TEST.Function).PIECE6()
ClassMethod PIECE6()
{
	SET numlist="123#456#789"
	WRITE !,"2-arg=",$PIECE(numlist,"#")
	WRITE !,"3-arg=",$PIECE(numlist,"#",1)
	WRITE !,"4-arg=",$PIECE(numlist,"#",1,1)
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE6()
 
2-arg=123
3-arg=123
4-arg=123

在下面的示例中,兩個$PIECE函式都回傳整個字串字串,因為在字串中沒有出現定界符:

/// d ##class(PHA.TEST.Function).PIECE7()
ClassMethod PIECE7()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	SET extract1=$PIECE(colorlist,"#")
	SET extract2=$PIECE(colorlist,"#",1,4)
	WRITE "#   =",extract1,!,"#,1,4=",extract2
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE7()
#   =Red,Green,Blue,Yellow,Orange,Black
#,1,4=Red,Green,Blue,Yellow,Orange,Black

以下示例$PIECE從物件屬性回傳第二個子字串:

/// d ##class(PHA.TEST.Function).PIECE8()
ClassMethod PIECE8()
{
	SET tStatement = ##class(%SQL.Statement).%New()
	SET tStatement.%SchemaPath="MyTests,Sample,Cinema"
	WRITE "whole schema path: ",tStatement.%SchemaPath,!
	WRITE "2nd piece of schema path: ",$PIECE(tStatement.%SchemaPath,",",2),!
}

DHC-APP>d ##class(PHA.TEST.Function).PIECE8()
whole schema path: MyTests,Sample,Cinema
2nd piece of schema path: Sample
 

以下兩個示例使用更復雜的定界符,

本示例使用定界符字串“#-#”回傳字串numlist的三個子字串,此處,定界字串的組成字符“#”“-”可用作資料值;僅保留指定的字符序列(#-#):

/// d ##class(PHA.TEST.Function).PIECE9()
ClassMethod PIECE9()
{
	SET numlist="1#2-3#-#45##6#-#789"
	WRITE !,$PIECE(numlist,"#-#",1)
	WRITE !,$PIECE(numlist,"#-#",2)
	WRITE !,$PIECE(numlist,"#-#",3)
}

DHC-APP>d ##class(PHA.TEST.Function).PIECE9()
 
1#2-3
45##6
789

下面的示例使用一個非ASCII分隔符(在本例中為pi的Unicode字符),該字符通過$CHAR函式指定,并通過連接運算子(_)插入到字串中:

/// d ##class(PHA.TEST.Function).PIECE10()
ClassMethod PIECE10()
{
	IF $SYSTEM.Version.IsUnicode()  {
		SET a = $CHAR(960)
		SET colorlist="Red"_a_"Green"_a_"Blue"
		SET extract1=$PIECE(colorlist,a)
		SET extract2=$PIECE(colorlist,a,2)
		SET extract3=$PIECE(colorlist,a,2,3)
		WRITE extract1,!,extract2,!,extract3
	} ELSE {
		WRITE "此示例需要Caché的Unicode安裝"
	}
}

DHC-APP>d ##class(PHA.TEST.Function).PIECE10()
Red
Green
GreenπBlue

使用SET $PIECE替換子字串

使用SET命令進行分配時,可以在等號的左側和右側使用$PIECE,在等號左側使用時,$PIECE指定要由分配的值替換的子字串,

$PIECE與等號左側的SET一起使用時,字串可以是有效的變數名,如果該變數不存在,則SET $PIECE對其進行定義,字串引數也可以是多維屬性參考,它不能是非多維物件屬性,嘗試在非多維物件屬性上使用SET $PIECE會導致<OBJECT DISPATCH>錯誤,

在這種情況下,$PIECE(以及$LIST$EXTRACT)的使用不同于其他標準函式,因為它修改了一個現有值,而不是僅僅回傳一個值,如果函式使用相對偏移語法,則不能將SET(a,b,c,...)= value語法與等號左邊的$PIECE(或$LIST或$EXTRACT)一起使用:*表示結尾一個字串,*-n* + n代表距字串末尾的相對偏移量,必須改為使用SET a = value,b = value,c = value,…語法,

示例:替換分隔的子字串

以下示例將顏色串列的值更改為"Magenta,Green,Cyan,Yellow,Orange,Black":

/// d ##class(PHA.TEST.Function).PIECE11()
ClassMethod PIECE11()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	WRITE colorlist,!
	SET $PIECE(colorlist,",",1)="Magenta"
	WRITE colorlist,!
	SET $PIECE(colorlist,",",*-3)="Cyan"
	WRITE colorlist,!
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE11()
Red,Green,Blue,Yellow,Orange,Black
Magenta,Green,Blue,Yellow,Orange,Black
Magenta,Green,Cyan,Yellow,Orange,Black

當然,替換子字串可以比原始子字串長或短,并且可以包括定界符:

/// d ##class(PHA.TEST.Function).PIECE12()
ClassMethod PIECE12()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	WRITE colorlist,!
	SET $PIECE(colorlist,",",3)="Turquoise,Aqua,Teal"
	WRITE colorlist,!
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE12()
Red,Green,Blue,Yellow,Orange,Black
Red,Green,Turquoise,Aqua,Teal,Yellow,Orange,Black
 

如果指定了from和to引數,則將包含的子字串替換為指定的值,在這種情況下,是第4到第6個定界子字串:

/// d ##class(PHA.TEST.Function).PIECE13()
ClassMethod PIECE13()
{
	SET colorlist="Red,Blue,Yellow,Green,Orange,Black"
	WRITE !,colorlist
	SET $PIECE(colorlist,",",4,6)="Yellow+Blue,Yellow+Red"
	WRITE !,colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE13()
 
Red,Blue,Yellow,Green,Orange,Black
Red,Blue,Yellow,Yellow+Blue,Yellow+Red

可以通過分隔的子字串計數(使用n)或從字串末尾的偏移量(使用* + n)追加一個或多個分隔的子字串, SET $PIECE根據需要附加其他定界符,以在指定位置附加定界的子字串,以下示例都將colorlist的值更改為“Green^Blue^^Red”,并使用額外的空字串分隔子字串進行填充:

/// d ##class(PHA.TEST.Function).PIECE14()
ClassMethod PIECE14()
{
	SET colorlist="Green^Blue"
	SET $PIECE(colorlist,"^",4)="Red"
	WRITE colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE14()
Green^Blue^^Red
/// d ##class(PHA.TEST.Function).PIECE15()
ClassMethod PIECE15()
{
	SET colorlist="Green^Blue"
	SET $PIECE(colorlist,"^",*+2)="Red"
	WRITE colorlist
}

DHC-APP>d ##class(PHA.TEST.Function).PIECE15()
Green^Blue^^Red

如果定界符未出現在字串中,則$PIECE會將字串視為單個片段,并執行與上述相同的替換,如果未指定from引數,則新值將替換原始字串:


/// d ##class(PHA.TEST.Function).PIECE16()
ClassMethod PIECE16()
{
	SET colorlist="Red,Green,Blue"
	WRITE colorlist,!
	SET $PIECE(colorlist,"^")="Purple^Orange"
	WRITE colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE16()
Red,Green,Blue
Purple^Orange

如果定界符未出現在字串中,并且from被指定為大于1的整數,則$PIECE將from-1定界符和提供的值附加到字串的末尾:

/// d ##class(PHA.TEST.Function).PIECE17()
ClassMethod PIECE17()
{
	SET colorlist="Red,Green,Blue"
	WRITE colorlist,!
	SET $PIECE(colorlist,"^",3)="Purple"
	WRITE colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE17()
Red,Green,Blue
Red,Green,Blue^^Purple

如果from表示字串開頭之前的位置,則Caché不執行任何操作:

/// d ##class(PHA.TEST.Function).PIECE18()
ClassMethod PIECE18()
{
	SET colorlist="Red,Green,Blue"
	WRITE colorlist,!
	SET $PIECE(colorlist,",",*-7)="Purple"
	WRITE colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE18()
Red,Green,Blue
Red,Green,Blue

如果from表示字串開頭之前的位置并提供to,則Caché將from視為位置1:

/// d ##class(PHA.TEST.Function).PIECE19()
ClassMethod PIECE19()
{
	SET colorlist="Red,Green,Blue"
	WRITE colorlist,!
	SET $PIECE(colorlist,",",*-7,1)="Purple"
	WRITE colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE19()
Red,Green,Blue
Purple,Green,Blue

初始化字串變數

在為字串變數賦值之前,不需要定義它,下面的示例將newvar初始化為字符模式“ >>>>>> TOTAL”

DHC-APP>SET $PIECE(newvar,">",7)="TOTAL"
 
DHC-APP>WRITE newvar
>>>>>>TOTAL

分隔符為空字串

如果定界符為空字串,則無論from和to引數的值如何,新值都會替換原始字串,

以下兩個示例都將顏色串列設定為“Purple”

/// d ##class(PHA.TEST.Function).PIECE20()
ClassMethod PIECE20()
{
	SET colorlist="Red,Green,Blue"
	WRITE !,colorlist
	SET $PIECE(colorlist,"")="Purple"
	WRITE !,colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE20()
 
Red,Green,Blue
Purple
/// d ##class(PHA.TEST.Function).PIECE21()
ClassMethod PIECE21()
{
	SET colorlist="Red,Blue,Yellow,Green,Orange,Black"
	WRITE !,colorlist
	SET $PIECE(colorlist,"",3,5)="Purple"
	WRITE !,colorlist
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE21()
 
Red,Blue,Yellow,Green,Orange,Black
Purple

引數超過32,768個字符的$PIECE

下面的示例創建一個由5個句點和一個null組成的字串:

/// d ##class(PHA.TEST.Function).PIECE22()
ClassMethod PIECE22()
{
	SET x=""
	SET $PIECE(x,".",6)=""
	WRITE x
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE22()
.....

現在考慮下面的示例,該示例創建一個32767的字串和一個null:

    SET x=""
    SET $PIECE(x,".",32768)=""

盡管從技術上講,它在字串的最大長度之內,但是如果未啟用長字串,則此示例將生成MAXSTRING>錯誤,默認情況下,長字串在系統范圍內啟用,如果希望將$PIECE與大于32,767個字符的引數一起使用,則可以使用Config.Miscellaneous類的EnableLongStrings屬性檢查或設定系統范圍的長字串設定,

注意

使用$PIECE解包資料值

$PIECE通常用于“解包”包含由分隔符分隔的多個欄位的資料值,典型的分隔符包括斜杠(/),逗號(),空格()和分號(;),以下樣本值是與$PIECE一起使用的良好候選者:

"John Jones/29 River St./Boston MA, 02095"
"Mumps;Measles;Chicken Pox;Diptheria"
"45.23,52.76,89.05,48.27"

$PIECE 與 $LENGTH

$LENGTH的兩個引數形式基于定界符回傳字串中子字串的數量,使用$LENGTH確定字串中子字串的數量,然后使用$PIECE提取單個子字串,如以下示例所示:

/// d ##class(PHA.TEST.Function).PIECE24()
ClassMethod PIECE24()
{
	SET sentence="The quick brown fox jumped over the lazy dog's back."
	SET delim=" "
	SET countdown=$LENGTH(sentence,delim)
	SET countup=1
	FOR reps=countdown:-1:1 {
		SET extract=$PIECE(sentence,delim,countup)
		WRITE !,countup," ",extract
		SET countup=countup+1
	}
	WRITE !,"All done!"
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE24()
 
1 The
2 quick
3 brown
4 fox
5 jumped
6 over
7 the
8 lazy
9 dog's
10 back.
All done!

Null Values

$PIECE不會區分帶有空字串值的帶分隔符的子字串和不存在的子字串,兩者都回傳一個空字串值,例如,下面的示例均回傳from值7的空字串:

/// d ##class(PHA.TEST.Function).PIECE25()
ClassMethod PIECE25()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	SET extract1=$PIECE(colorlist,",",6)
	SET extract2=$PIECE(colorlist,",",7)
	WRITE "6=",extract1,!,"7=",extract2
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE25()
6=Black
7=
/// d ##class(PHA.TEST.Function).PIECE26()
ClassMethod PIECE26()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black,"
	SET extract1=$PIECE(colorlist,",",6)
	SET extract2=$PIECE(colorlist,",",7)
	WRITE "6=",extract1,!,"7=",extract2
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE26()
6=Black
7=

在第一種情況下,沒有第七個子字串;回傳一個空字串,在第二種情況下,有第七個子字串,如字串末尾的定界符所指示;該第七個子字串的值是空字串,

下面的示例顯示字串中的空值,它提取子字串1和3,這些子字串存在,但都包含一個空字串, (子字串1定義為第一個定界符之前的字串):

/// d ##class(PHA.TEST.Function).PIECE27()
ClassMethod PIECE27()
{
	SET colorlist=",Red,,Blue,"
	SET extract1=$PIECE(colorlist,",")
	SET extract3=$PIECE(colorlist,",",3)
	WRITE !,"sub1=",extract1,!,"sub3=",extract3
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE27()
 
sub1=
sub3=

以下示例還回傳一個空字串,因為指定的子字串不存在:

/// d ##class(PHA.TEST.Function).PIECE28()
ClassMethod PIECE28()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	SET extract=$PIECE(colorlist,",",0)
	WRITE !,"Length=",$LENGTH(extract),!,"Value=",extract
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE28()
 
Length=0
Value=
/// d ##class(PHA.TEST.Function).PIECE29()
ClassMethod PIECE29()
{
	SET colorlist="Red,Green,Blue,Yellow,Orange,Black"
	SET extract=$PIECE(colorlist,",",8,20)
	WRITE !,"Length=",$LENGTH(extract),!,"Value=",extract
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE29()
 
Length=0
Value=

強制數值計算

$PIECE(或任何ObjectScript函式)前加一元+號可強制對回傳值進行數值計算,它以規范形式回傳數字子字串,它回傳一個非數字子字串為0,它回傳一個混合數字子字串的前導數字部分,對于空字串值或不存在的子字串,它將回傳0,

/// d ##class(PHA.TEST.Function).PIECE30()
ClassMethod PIECE30()
{
	SET str="snow white,7dwarves,+007.00,99.90,,-0,"
	WRITE "Substrings:",!
	FOR i=1:1:7 {WRITE i,"=",$PIECE(str,",",i)," "}
	WRITE !,"Forced Numerics:",!
	FOR i=1:1:7 {WRITE i,"=",+$PIECE(str,",",i)," "}
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE30()
Substrings:
1=snow white 2=7dwarves 3=+007.00 4=99.90 5= 6=-0 7=
Forced Numerics:
1=0 2=7 3=7 4=99.9 5=0 6=0 7=0

嵌套$PIECE操作

要執行復雜的提取,可以將 $PIECE參考彼此嵌套,內部$PIECE回傳一個由外部$PIECE操作的子字串,每個$PIECE使用其自己的定界符,例如,以下回傳狀態縮寫“MA”

/// d ##class(PHA.TEST.Function).PIECE31()
ClassMethod PIECE31()
{
	SET patient="John Jones/29 River St./Boston MA 02095"
	SET patientstateaddress=$PIECE($PIECE(patient,"/",3)," ",2)
	WRITE patientstateaddress
}
DHC-APP>d ##class(PHA.TEST.Function).PIECE31()
MA

以下是使用定界符層次結構嵌套$PIECE操作的另一個示例,首先,內部$PIECE使用脫字符號(^)分隔符查找第二個嵌套串列:“A,B,C”,然后,外部$PIECE使用逗號()分隔符回傳子字串“A,B,C”的第一部分和第二部分(“A,B”):

/// d ##class(PHA.TEST.Function).PIECE32()
ClassMethod PIECE32()
{
	SET nestlist="1,2,3^A,B,C^@#!"
	WRITE $PIECE($PIECE(nestlist,"^",2),",",1,2)
}
DHC-APP> d ##class(PHA.TEST.Function).PIECE32()
A,B

$PIECE$EXTRACT$LIST的比較

$PIECE通過計算字串中用戶定義的定界符來確定子字串, $PIECE將包含要用作定界符的一個或多個字符實體的普通字串作為輸入,

$EXTRACT通過從字串開頭計數字符來確定子字串, $EXTRACT將普通字串作為輸入,

$LIST通過從串列的開頭計數元素(而非字符)來確定編碼串列中的元素, $LIST函式無需使用指定的分隔符即可指定子字串,如果預留定界符或字符序列不適合資料型別(例如,位串資料),則應使用$LISTBUILD$LIST函式存盤和檢索子串,可以使用$LISTFROMSTRING函式將定界字串轉換為串列,可以使用$LISTTOSTRING函式將串列轉換為定界字串,

$PIECE$LIST函式使用的資料存盤策略不兼容,因此不應將其結合使用,例如,嘗試在使用$LISTBUILD創建的串列上使用$PIECE會產生不可預測的結果,應避免使用,

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/167961.html

標籤:其他

上一篇:mysql資料庫主從同步中斷的各種情況

下一篇:mysql 計算時間函式差

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:40:31 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:40:11 more
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:39:36 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:39:13 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:16:23 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:16:15 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:15:46 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:14:53 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:14:08 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:08:34 more