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

第四十九章 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会产生不可预测的结果,应避免使用。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351