XERROR.TYPE

XERROR.TYPE(reference,[analysis_type],[if_not_error])
reference
Required. Specifies the function input
analysis_type
Optional. Specifies the type of output data and takes one of three arguments: 0 or omitted, for numeric error-type output; 1, for text (descriptive) output; and 2, for numeric error-number output, same as Excel's built-in ERROR.TYPE
if_not_error
Optional. Specifies what output to display for function entries that are not errors and can take a single entry of any data type (i.e. number, text, blank, logical, or error) (#N/A if omitted)

XERROR.TYPE displays the XTYPE-style error type or error name for all Excel errors

Rnkhch

Well-known Member
Joined
Apr 28, 2018
Messages
528
Office Version
  1. 365
Platform
  1. Windows
XERROR.TYPE displays the XTYPE-style error type or error name for all Excel errors

XERROR.TYPE takes three parameters, one requires, and two optional, as follows:
A) The first parameter, required, specifies the input and can be a single cell, range, or array.

B) The second parameter, optional, specifies the type of output data and takes one of three arguments:
0 or omitted, for numeric error-type output
1, for text (descriptive) output
2, for numeric error-number output, same as Excel's built-in ERROR.TYPE

C) The third parameter, optional, specifies what output to display for function entries that are not errors and can take a single entry of any data type (i.e. number, text, blank, logical, or error). If omitted, an #N/A error will be displayed by default

XERROR.TYPE
VBA Code:
=LAMBDA(reference,[analysis_type],[if_not_error],
   IF(IO(reference),
   NA(),
   LET(
      a,PLS(PO0(analysis_type)),
      o,SWITCH(a,
         0,SWITCH(ERROR.TYPE(reference),0,160,1,161,2,162,3,163,4,164,5,165,6,166,7,167,8,168,9,169,10,1610,11,1611,12,1612,13,1613,14,1614),
         1,SWITCH(ERROR.TYPE(reference),0,"dt:ERROR_EXTERNAL!",1,"dt:ERROR_NULL!",2,"dt:ERROR_DIV/0!",3,"dt:ERROR_VALUE!",4,"dt:ERROR_REF!",5,"dt:ERROR_NAME?",6,"dt:ERROR_NUM!",7,"dt:ERROR_N/A",8,"dt:ERROR_GETTING_Data",9,"dt:ERROR_SPILL!",10,"dt:ERROR_CONNECT!",11,"dt:ERROR_BLOCKED!",12,"dt:ERROR_UNKNOWN!",13,"dt:ERROR_FIELD!",14,"dt:ERROR_CALC!"),
         2,ERROR.TYPE(reference)),
      IF(
         ISERROR(a),
         o,
         IF(
            ISNOTARRAY(if_not_error),
            IF(IO(if_not_error),o,IF(ISERROR(o),if_not_error,o)),
            NA()
            )
        )
      )
   )
)

The following helper functions are also used in the code. Full code and descriptions are included in my "Blank power workbook" template, which you can download through the link in my signature below:

IO (shortened form of ISOMITTED)
VBA Code:
=LAMBDA(parameter,ISOMITTED(parameter))

PLS (limits parameter to only a single entry)
VBA Code:
=LAMBDA(parameter,JAN(IF(OR(ISARRAY(parameter),ISERRORS(parameter),ISBLANKS(parameter)),NA(),parameter)))

PO0 (Returns 0 if the parameter is omitted and the parameter itself otherwise)
VBA Code:
=LAMBDA([parameter],IF(IO(parameter),0,parameter))

ISNOTARRAY (Returns TRUE if the reference is not an array [i.e. is a single element or is omitted] and FALSE otherwise)
VBA Code:
=LAMBDA([reference],[output],LET(r,IFERROR(reference,""),o,PLSL(output),m,IF(IO(reference),TRUE,IF(RBYC(r)=1,TRUE,FALSE)),JAO(m,o)))

XERROR.TYPE.xlsx
ABCDEFGHIJKLMN
1
2#CALC!
3
4#N/A(reference from blank cell)
5#VALUE!(no reference)
6if_not_error
7reference input from cells individuallyreference input from cells as range (for spill output)not error
8analysis_typeanalysis_type
9error typeerroromitted012omitted0120
100#EXTERNAL!160160dt:ERROR_EXTERNAL!0160160dt:ERROR_EXTERNAL!0160
111#NULL!161161dt:ERROR_NULL!1161161dt:ERROR_NULL!1161
122#DIV/0!162162dt:ERROR_DIV/0!2162162dt:ERROR_DIV/0!2162
133#VALUE!163163dt:ERROR_VALUE!3163163dt:ERROR_VALUE!3163
144#REF!164164dt:ERROR_REF!4164164dt:ERROR_REF!4164
155#NAME?165165dt:ERROR_NAME?5165165dt:ERROR_NAME?5165
166#NUM!166166dt:ERROR_NUM!6166166dt:ERROR_NUM!6166
177#N/A167167dt:ERROR_N/A7167167dt:ERROR_N/A7167
188#GETTING_DATA168168dt:ERROR_GETTING_Data8168168dt:ERROR_GETTING_Data8168
1913#FIELD!16131613dt:ERROR_FIELD!1316131613dt:ERROR_FIELD!131613
2014#CALC!16141614dt:ERROR_CALC!1416141614dt:ERROR_CALC!141614
21n/a43#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
22n/abook#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
23n/aTRUE#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
24n/aFALSE#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
25n/a""#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
26
27if_not_error
28reference input directly individuallynot error
29analysis_type
30error typeerroromitted0120
310#EXTERNAL!160160dt:ERROR_EXTERNAL!0160
321#NULL!161161dt:ERROR_NULL!1161
332#DIV/0!162162dt:ERROR_DIV/0!2162
343#VALUE!163163dt:ERROR_VALUE!3163
354#REF!164164dt:ERROR_REF!4164
365#NAME?165165dt:ERROR_NAME?5165
376#NUM!166166dt:ERROR_NUM!6166
387#N/A167167dt:ERROR_N/A7167
398#GETTING_DATA168168dt:ERROR_GETTING_Data8168
40n/a43#N/A#N/A#N/A#N/Anot error
41n/abook#N/A#N/A#N/A#N/Anot error
42n/abook (wihout quotes)165165dt:ERROR_NAME?5165
43n/aTRUE#N/A#N/A#N/A#N/Anot error
44n/aFALSE#N/A#N/A#N/A#N/Anot error
45n/a""#N/A#N/A#N/A#N/Anot error
46
47if_not_error
48reference input directly as array (for spill output)not error
49analysis_type
50error typeerroromitted0120
510#EXTERNAL!160160dt:ERROR_EXTERNAL!0160
521#NULL!161161dt:ERROR_NULL!1161
532#DIV/0!162162dt:ERROR_DIV/0!2162
543#VALUE!163163dt:ERROR_VALUE!3163
554#REF!164164dt:ERROR_REF!4164
565#NAME?165165dt:ERROR_NAME?5165
576#NUM!166166dt:ERROR_NUM!6166
587#N/A167167dt:ERROR_N/A7167
598#GETTING_DATA168168dt:ERROR_GETTING_Data8168
60n/a43#N/A#N/A#N/A#N/Anot error
61n/abook#N/A#N/A#N/A#N/Anot error
62n/aTRUE#N/A#N/A#N/A#N/Anot error
63n/aFALSE#N/A#N/A#N/A#N/Anot error
64n/a""#N/A#N/A#N/A#N/Anot error
65
Sheet1
Cell Formulas
RangeFormula
B2B2=LAMBDA(reference,[analysis_type],[if_not_error],IF(IO(reference),NA(),LET(a,PLS(PO0(analysis_type)),o,SWITCH(a,0,SWITCH(ERROR.TYPE(reference),0,160,1,161,2,162,3,163,4,164,5,165,6,166,7,167,8,168,9,169,10,1610,11,1611,12,1612,13,1613,14,1614),1,SWITCH(ERROR.TYPE(reference),0,"dt:ERROR_EXTERNAL!",1,"dt:ERROR_NULL!",2,"dt:ERROR_DIV/0!",3,"dt:ERROR_VALUE!",4,"dt:ERROR_REF!",5,"dt:ERROR_NAME?",6,"dt:ERROR_NUM!",7,"dt:ERROR_N/A",8,"dt:ERROR_GETTING_Data",9,"dt:ERROR_SPILL!",10,"dt:ERROR_CONNECT!",11,"dt:ERROR_BLOCKED!",12,"dt:ERROR_UNKNOWN!",13,"dt:ERROR_FIELD!",14,"dt:ERROR_CALC!"),2,ERROR.TYPE(reference)),IF(ISERROR(a),o,IF(ISNOTARRAY(if_not_error),IF(IO(if_not_error),o,IF(ISERROR(o),if_not_error,o)),NA())))))
C4,D10:D25C4=XERROR.TYPE(B4)
C5C5=XERROR.TYPE()
E10:E25E10=XERROR.TYPE(C10,0)
F10:F25F10=XERROR.TYPE(C10,1)
G10:G25G10=XERROR.TYPE(C10,2)
H10:H25H10=XERROR.TYPE(C10:C25)
I10:I25I10=XERROR.TYPE(C10:C25,0)
J10:J25J10=XERROR.TYPE(C10:C25,1)
K10:K25K10=XERROR.TYPE(C10:C25,2)
C10:C20,C51:C59,C31:C39C10=XERROR(B10)
M10M10=XERROR.TYPE(C10,0,M7)
M11M11=XERROR.TYPE(C11,0,M7)
M12M12=XERROR.TYPE(C12,0,M7)
M13M13=XERROR.TYPE(C13,0,M7)
M14M14=XERROR.TYPE(C14,0,M7)
M15M15=XERROR.TYPE(C15,0,M7)
M16M16=XERROR.TYPE(C16,0,M7)
M17M17=XERROR.TYPE(C17,0,M7)
M18M18=XERROR.TYPE(C18,0,M7)
M19M19=XERROR.TYPE(C19,0,M7)
M20M20=XERROR.TYPE(C20,0,M7)
M21M21=XERROR.TYPE(C21,0,M7)
M22M22=XERROR.TYPE(C22,0,M7)
M23M23=XERROR.TYPE(C23,0,M7)
M24M24=XERROR.TYPE(C24,0,M7)
M25M25=XERROR.TYPE(C25,0,M7)
D31D31=XERROR.TYPE(#EXTERNAL!)
E31E31=XERROR.TYPE(#EXTERNAL!,0)
F31F31=XERROR.TYPE(#EXTERNAL!,1)
G31G31=XERROR.TYPE(#EXTERNAL!,2)
D32D32=XERROR.TYPE(#NULL!)
E32E32=XERROR.TYPE(#NULL!,0)
F32F32=XERROR.TYPE(#NULL!,1)
G32G32=XERROR.TYPE(#NULL!,2)
D33D33=XERROR.TYPE(#DIV/0!)
E33E33=XERROR.TYPE(#DIV/0!,0)
F33F33=XERROR.TYPE(#DIV/0!,1)
G33G33=XERROR.TYPE(#DIV/0!,2)
D34D34=XERROR.TYPE(#VALUE!)
E34E34=XERROR.TYPE(#VALUE!,0)
F34F34=XERROR.TYPE(#VALUE!,1)
G34G34=XERROR.TYPE(#VALUE!,2)
D35D35=XERROR.TYPE(#REF!)
E35E35=XERROR.TYPE(#REF!,0)
F35F35=XERROR.TYPE(#REF!,1)
G35G35=XERROR.TYPE(#REF!,2)
D36D36=XERROR.TYPE(#NAME?)
E36E36=XERROR.TYPE(#NAME?,0)
F36F36=XERROR.TYPE(#NAME?,1)
G36G36=XERROR.TYPE(#NAME?,2)
D37D37=XERROR.TYPE(#NUM!)
E37E37=XERROR.TYPE(#NUM!,0)
F37F37=XERROR.TYPE(#NUM!,1)
G37G37=XERROR.TYPE(#NUM!,2)
D38D38=XERROR.TYPE(#N/A)
E38E38=XERROR.TYPE(#N/A,0)
F38F38=XERROR.TYPE(#N/A,1)
G38G38=XERROR.TYPE(#N/A,2)
D39D39=XERROR.TYPE(#GETTING_DATA)
E39E39=XERROR.TYPE(#GETTING_DATA,0)
F39F39=XERROR.TYPE(#GETTING_DATA,1)
G39G39=XERROR.TYPE(#GETTING_DATA,2)
D40D40=XERROR.TYPE(43)
E40E40=XERROR.TYPE(43,0)
F40F40=XERROR.TYPE(43,1)
G40G40=XERROR.TYPE(43,2)
D41D41=XERROR.TYPE("book")
E41E41=XERROR.TYPE("book",0)
F41F41=XERROR.TYPE("book",1)
G41G41=XERROR.TYPE("book",2)
D42D42=XERROR.TYPE(book)
E42E42=XERROR.TYPE(book,0)
F42F42=XERROR.TYPE(book,1)
G42G42=XERROR.TYPE(book,2)
D43D43=XERROR.TYPE(TRUE)
E43E43=XERROR.TYPE(TRUE,0)
F43F43=XERROR.TYPE(TRUE,1)
G43G43=XERROR.TYPE(TRUE,2)
D44D44=XERROR.TYPE(FALSE)
E44E44=XERROR.TYPE(FALSE,0)
F44F44=XERROR.TYPE(FALSE,1)
G44G44=XERROR.TYPE(FALSE,2)
D45D45=XERROR.TYPE("")
E45E45=XERROR.TYPE("",0)
F45F45=XERROR.TYPE("",1)
G45G45=XERROR.TYPE("",2)
I31I31=XERROR.TYPE(#EXTERNAL!,0,I28)
I32I32=XERROR.TYPE(#NULL!,0,I28)
I33I33=XERROR.TYPE(#DIV/0!,0,I28)
I34I34=XERROR.TYPE(#VALUE!,0,I28)
I35I35=XERROR.TYPE(#REF!,0,I28)
I36I36=XERROR.TYPE(#NAME?,0,I28)
I37I37=XERROR.TYPE(#NUM!,0,I28)
I38I38=XERROR.TYPE(#N/A,0,I28)
I39I39=XERROR.TYPE(#GETTING_DATA,0,I28)
I40I40=XERROR.TYPE(43,0,I28)
I41I41=XERROR.TYPE("book",0,I28)
I42I42=XERROR.TYPE(book,0,I28)
I43I43=XERROR.TYPE(TRUE,0,I28)
I44I44=XERROR.TYPE(FALSE,0,I28)
I45I45=XERROR.TYPE("",0,I28)
D51:D64D51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""})
E51:E64E51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},0)
F51:F64F51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},1)
G51:G64G51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},2)
I51:I64I51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},0,I48)
Dynamic array formulas.
 
Upvote 0
Quick update for the code:

XERROR.TYPE
VBA Code:
=LAMBDA(reference,[analysis_type],[if_not_error],
   IF(
      IO(reference),
      NA(),
      LET(
         a,PLS(PO0(analysis_type)),
         o,SWITCH(a,0,SWITCH(ERROR.TYPE(reference),0,160,1,161,2,162,3,163,4,164,5,165,6,166,7,167,8,168,9,169,10,1610,11,1611,12,1612,13,1613,14,1614),1,SWITCH(ERROR.TYPE(reference),0,"dt:ERROR_EXTERNAL!",1,"dt:ERROR_NULL!",2,"dt:ERROR_DIV/0!",3,"dt:ERROR_VALUE!",4,"dt:ERROR_REF!",5,"dt:ERROR_NAME?",6,"dt:ERROR_NUM!",7,"dt:ERROR_N/A",8,"dt:ERROR_GETTING_Data",9,"dt:ERROR_SPILL!",10,"dt:ERROR_CONNECT!",11,"dt:ERROR_BLOCKED!",12,"dt:ERROR_UNKNOWN!",13,"dt:ERROR_FIELD!",14,"dt:ERROR_CALC!"),2,ERROR.TYPE(reference)),
         IF(
            ISERROR(a),
            o,
            IF(
               ISARRAY(if_not_error),
               NA(),
               IF(IO(if_not_error),o,IF(ISERROR(o),if_not_error,o))
            )
         )
      )
   )
)

IO (shortened form of ISOMITTED)
VBA Code:
=LAMBDA(parameter,ISOMITTED(parameter))

PLS (limits parameter to only a single entry)
VBA Code:
=LAMBDA(parameter,INDEX(IF(OR(ISARRAY(parameter),ISERRORS(parameter),ISBLANKS(parameter)),NA(),parameter),1))

PO0 (Returns 0 if the parameter is omitted and the parameter itself otherwise)
VBA Code:
=LAMBDA([parameter],IF(IO(parameter),0,parameter))

ISARRAY (Returns TRUE if the reference is an array (i.e. is not a single element or is not omitted) and FALSE otherwise)
VBA Code:
=LAMBDA([reference],[output],LET(r,IFERROR(IF(reference="","",reference),""),o,PLSL(output),m,IF(IO(reference),FALSE,IF(ROWS(r)*COLUMNS(r)>1,TRUE,FALSE)),IF(m,OT(o),OF(o))))

PLSL (Returns 1 if the parameter is a single TRUE entry; 0 if the parameter is a single FALSE entry or omitted; and #N/A otherwise)
VBA Code:
=LAMBDA([parameter],IF(IO(parameter),0,IF(ISARRAY(parameter),NA(),LET(p,INDEX(parameter,1),IF(ISERROR(p),NA(),T1F0(p))))))

T1F0 (Returns 1 if the reference is TRUE and 0 if the reference is FALSE)
VBA Code:
=LAMBDA(reference,[analysis_type],LET(a,PLSL(analysis_type),b,IF(ISNUMBER(reference)+ISLOGICAL(reference),reference,SWITCH(a,0,NA(),1,0)),IF(b,1,0)))

XERROR.TYPE.xlsx
ABCDEFGHIJKLMN
1
2#CALC!
3
4#N/A(reference from blank cell)
5#VALUE!(no reference)
6if_not_error
7reference input from cells individuallyreference input from cells as range (for spill output)not error
8analysis_typeanalysis_type
9error typeerroromitted012omitted0120
100#EXTERNAL!160160dt:ERROR_EXTERNAL!0160160dt:ERROR_EXTERNAL!0160
111#NULL!161161dt:ERROR_NULL!1161161dt:ERROR_NULL!1161
122#DIV/0!162162dt:ERROR_DIV/0!2162162dt:ERROR_DIV/0!2162
133#VALUE!163163dt:ERROR_VALUE!3163163dt:ERROR_VALUE!3163
144#REF!164164dt:ERROR_REF!4164164dt:ERROR_REF!4164
155#NAME?165165dt:ERROR_NAME?5165165dt:ERROR_NAME?5165
166#NUM!166166dt:ERROR_NUM!6166166dt:ERROR_NUM!6166
177#N/A167167dt:ERROR_N/A7167167dt:ERROR_N/A7167
188#GETTING_DATA168168dt:ERROR_GETTING_Data8168168dt:ERROR_GETTING_Data8168
1913#FIELD!16131613dt:ERROR_FIELD!1316131613dt:ERROR_FIELD!131613
2014#CALC!16141614dt:ERROR_CALC!1416141614dt:ERROR_CALC!141614
21n/a43#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
22n/abook#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
23n/aTRUE#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
24n/aFALSE#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
25n/a""#N/A#N/A#N/A#N/A#N/A#N/A#N/A#N/Anot error
26
27if_not_error
28reference input directly individuallynot error
29analysis_type
30error typeerroromitted0120
310#EXTERNAL!160160dt:ERROR_EXTERNAL!0160
321#NULL!161161dt:ERROR_NULL!1161
332#DIV/0!162162dt:ERROR_DIV/0!2162
343#VALUE!163163dt:ERROR_VALUE!3163
354#REF!164164dt:ERROR_REF!4164
365#NAME?165165dt:ERROR_NAME?5165
376#NUM!166166dt:ERROR_NUM!6166
387#N/A167167dt:ERROR_N/A7167
398#GETTING_DATA168168dt:ERROR_GETTING_Data8168
40n/a43#N/A#N/A#N/A#N/Anot error
41n/abook#N/A#N/A#N/A#N/Anot error
42n/abook (wihout quotes)165165dt:ERROR_NAME?5165
43n/aTRUE#N/A#N/A#N/A#N/Anot error
44n/aFALSE#N/A#N/A#N/A#N/Anot error
45n/a""#N/A#N/A#N/A#N/Anot error
46
47if_not_error
48reference input directly as array (for spill output)not error
49analysis_type
50error typeerroromitted0120
510#EXTERNAL!160160dt:ERROR_EXTERNAL!0160
521#NULL!161161dt:ERROR_NULL!1161
532#DIV/0!162162dt:ERROR_DIV/0!2162
543#VALUE!163163dt:ERROR_VALUE!3163
554#REF!164164dt:ERROR_REF!4164
565#NAME?165165dt:ERROR_NAME?5165
576#NUM!166166dt:ERROR_NUM!6166
587#N/A167167dt:ERROR_N/A7167
598#GETTING_DATA168168dt:ERROR_GETTING_Data8168
60n/a43#N/A#N/A#N/A#N/Anot error
61n/abook#N/A#N/A#N/A#N/Anot error
62n/aTRUE#N/A#N/A#N/A#N/Anot error
63n/aFALSE#N/A#N/A#N/A#N/Anot error
64n/a""#N/A#N/A#N/A#N/Anot error
65
Sheet1
Cell Formulas
RangeFormula
B2B2=LAMBDA(reference,[analysis_type],[if_not_error],IF(IO(reference),NA(),LET(a,PLS(PO0(analysis_type)),o,SWITCH(a,0,SWITCH(ERROR.TYPE(reference),0,160,1,161,2,162,3,163,4,164,5,165,6,166,7,167,8,168,9,169,10,1610,11,1611,12,1612,13,1613,14,1614),1,SWITCH(ERROR.TYPE(reference),0,"dt:ERROR_EXTERNAL!",1,"dt:ERROR_NULL!",2,"dt:ERROR_DIV/0!",3,"dt:ERROR_VALUE!",4,"dt:ERROR_REF!",5,"dt:ERROR_NAME?",6,"dt:ERROR_NUM!",7,"dt:ERROR_N/A",8,"dt:ERROR_GETTING_Data",9,"dt:ERROR_SPILL!",10,"dt:ERROR_CONNECT!",11,"dt:ERROR_BLOCKED!",12,"dt:ERROR_UNKNOWN!",13,"dt:ERROR_FIELD!",14,"dt:ERROR_CALC!"),2,ERROR.TYPE(reference)),IF(ISERROR(a),o,IF(ISARRAY(if_not_error),NA(),IF(IO(if_not_error),o,IF(ISERROR(o),if_not_error,o)))))))
C4,D10:D25C4=XERROR.TYPE(B4)
C5C5=XERROR.TYPE()
E10:E25E10=XERROR.TYPE(C10,0)
F10:F25F10=XERROR.TYPE(C10,1)
G10:G25G10=XERROR.TYPE(C10,2)
H10:H25H10=XERROR.TYPE(C10:C25)
I10:I25I10=XERROR.TYPE(C10:C25,0)
J10:J25J10=XERROR.TYPE(C10:C25,1)
K10:K25K10=XERROR.TYPE(C10:C25,2)
C10:C20,C51:C59,C31:C39C10=XERROR(B10)
M10M10=XERROR.TYPE(C10,0,M7)
M11M11=XERROR.TYPE(C11,0,M7)
M12M12=XERROR.TYPE(C12,0,M7)
M13M13=XERROR.TYPE(C13,0,M7)
M14M14=XERROR.TYPE(C14,0,M7)
M15M15=XERROR.TYPE(C15,0,M7)
M16M16=XERROR.TYPE(C16,0,M7)
M17M17=XERROR.TYPE(C17,0,M7)
M18M18=XERROR.TYPE(C18,0,M7)
M19M19=XERROR.TYPE(C19,0,M7)
M20M20=XERROR.TYPE(C20,0,M7)
M21M21=XERROR.TYPE(C21,0,M7)
M22M22=XERROR.TYPE(C22,0,M7)
M23M23=XERROR.TYPE(C23,0,M7)
M24M24=XERROR.TYPE(C24,0,M7)
M25M25=XERROR.TYPE(C25,0,M7)
D31D31=XERROR.TYPE(#EXTERNAL!)
E31E31=XERROR.TYPE(#EXTERNAL!,0)
F31F31=XERROR.TYPE(#EXTERNAL!,1)
G31G31=XERROR.TYPE(#EXTERNAL!,2)
D32D32=XERROR.TYPE(#NULL!)
E32E32=XERROR.TYPE(#NULL!,0)
F32F32=XERROR.TYPE(#NULL!,1)
G32G32=XERROR.TYPE(#NULL!,2)
D33D33=XERROR.TYPE(#DIV/0!)
E33E33=XERROR.TYPE(#DIV/0!,0)
F33F33=XERROR.TYPE(#DIV/0!,1)
G33G33=XERROR.TYPE(#DIV/0!,2)
D34D34=XERROR.TYPE(#VALUE!)
E34E34=XERROR.TYPE(#VALUE!,0)
F34F34=XERROR.TYPE(#VALUE!,1)
G34G34=XERROR.TYPE(#VALUE!,2)
D35D35=XERROR.TYPE(#REF!)
E35E35=XERROR.TYPE(#REF!,0)
F35F35=XERROR.TYPE(#REF!,1)
G35G35=XERROR.TYPE(#REF!,2)
D36D36=XERROR.TYPE(#NAME?)
E36E36=XERROR.TYPE(#NAME?,0)
F36F36=XERROR.TYPE(#NAME?,1)
G36G36=XERROR.TYPE(#NAME?,2)
D37D37=XERROR.TYPE(#NUM!)
E37E37=XERROR.TYPE(#NUM!,0)
F37F37=XERROR.TYPE(#NUM!,1)
G37G37=XERROR.TYPE(#NUM!,2)
D38D38=XERROR.TYPE(#N/A)
E38E38=XERROR.TYPE(#N/A,0)
F38F38=XERROR.TYPE(#N/A,1)
G38G38=XERROR.TYPE(#N/A,2)
D39D39=XERROR.TYPE(#GETTING_DATA)
E39E39=XERROR.TYPE(#GETTING_DATA,0)
F39F39=XERROR.TYPE(#GETTING_DATA,1)
G39G39=XERROR.TYPE(#GETTING_DATA,2)
D40D40=XERROR.TYPE(43)
E40E40=XERROR.TYPE(43,0)
F40F40=XERROR.TYPE(43,1)
G40G40=XERROR.TYPE(43,2)
D41D41=XERROR.TYPE("book")
E41E41=XERROR.TYPE("book",0)
F41F41=XERROR.TYPE("book",1)
G41G41=XERROR.TYPE("book",2)
D42D42=XERROR.TYPE(book)
E42E42=XERROR.TYPE(book,0)
F42F42=XERROR.TYPE(book,1)
G42G42=XERROR.TYPE(book,2)
D43D43=XERROR.TYPE(TRUE)
E43E43=XERROR.TYPE(TRUE,0)
F43F43=XERROR.TYPE(TRUE,1)
G43G43=XERROR.TYPE(TRUE,2)
D44D44=XERROR.TYPE(FALSE)
E44E44=XERROR.TYPE(FALSE,0)
F44F44=XERROR.TYPE(FALSE,1)
G44G44=XERROR.TYPE(FALSE,2)
D45D45=XERROR.TYPE("")
E45E45=XERROR.TYPE("",0)
F45F45=XERROR.TYPE("",1)
G45G45=XERROR.TYPE("",2)
I31I31=XERROR.TYPE(#EXTERNAL!,0,I28)
I32I32=XERROR.TYPE(#NULL!,0,I28)
I33I33=XERROR.TYPE(#DIV/0!,0,I28)
I34I34=XERROR.TYPE(#VALUE!,0,I28)
I35I35=XERROR.TYPE(#REF!,0,I28)
I36I36=XERROR.TYPE(#NAME?,0,I28)
I37I37=XERROR.TYPE(#NUM!,0,I28)
I38I38=XERROR.TYPE(#N/A,0,I28)
I39I39=XERROR.TYPE(#GETTING_DATA,0,I28)
I40I40=XERROR.TYPE(43,0,I28)
I41I41=XERROR.TYPE("book",0,I28)
I42I42=XERROR.TYPE(book,0,I28)
I43I43=XERROR.TYPE(TRUE,0,I28)
I44I44=XERROR.TYPE(FALSE,0,I28)
I45I45=XERROR.TYPE("",0,I28)
D51:D64D51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""})
E51:E64E51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},0)
F51:F64F51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},1)
G51:G64G51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},2)
I51:I64I51=XERROR.TYPE({#EXTERNAL!;#NULL!;#DIV/0!;#VALUE!;#REF!;#NAME?;#NUM!;#N/A;#GETTING_DATA;43;"book";TRUE;FALSE;""},0,I48)
Dynamic array formulas.
 

Forum statistics

Threads
1,216,503
Messages
6,131,022
Members
449,616
Latest member
PsychoCube

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top