pub struct DCountFn;Trait Implementations§
Source§impl Function for DCountFn
Counts numeric cells in a database field for records matching criteria.
impl Function for DCountFn
Counts numeric cells in a database field for records matching criteria.
DCOUNT ignores non-numeric values in the selected field even when the row itself matches.
§Remarks
- Criteria rows are ORed, and criteria columns inside a single row are ANDed.
fieldheader lookup is case-insensitive, and numericfielduses 1-based indexing; unresolved headers or invalid indexes return#VALUE!.- Only numeric field values contribute to the count.
§Examples
title: "Count numeric revenue entries in East region"
grid:
A1: "Region"
B1: "Salesperson"
C1: "Product"
D1: "Units"
E1: "Revenue"
A2: "West"
B2: "Diaz"
C2: "Widget"
D2: 24
E2: 126000
A3: "East"
B3: "Patel"
C3: "Gadget"
D3: 31
E3: 142500
A4: "North"
B4: "Kim"
C4: "Widget"
D4: 18
E4: 87000
A5: "West"
B5: "Ramos"
C5: "Service"
D5: 12
E5: 46000
A6: "South"
B6: "Lee"
C6: "Gadget"
D6: 27
E6: 119000
A7: "East"
B7: "Noor"
C7: "Widget"
D7: 22
E7: 101000
G1: "Region"
G2: "East"
formula: "=DCOUNT(A1:E7, \"Revenue\", G1:G2)"
expected: 2title: "Count numeric units for Widget or Service products"
grid:
A1: "Region"
B1: "Salesperson"
C1: "Product"
D1: "Units"
E1: "Revenue"
A2: "West"
B2: "Diaz"
C2: "Widget"
D2: 24
E2: 126000
A3: "East"
B3: "Patel"
C3: "Gadget"
D3: 31
E3: 142500
A4: "North"
B4: "Kim"
C4: "Widget"
D4: 18
E4: 87000
A5: "West"
B5: "Ramos"
C5: "Service"
D5: 12
E5: 46000
A6: "South"
B6: "Lee"
C6: "Gadget"
D6: 27
E6: 119000
A7: "East"
B7: "Noor"
C7: "Widget"
D7: 22
E7: 101000
G1: "Product"
G2: "Widget"
G3: "Service"
formula: "=DCOUNT(A1:E7, 4, G1:G3)"
expected: 4related:
- DCOUNTA
- DSUM
- COUNTIFS
faq:
- q: "Does DCOUNT count text values that look like numbers?"
a: "Only values resolved as numeric in the target field are counted; true non-numeric text is ignored."[formualizer-docgen:schema:start] Name: DCOUNT Type: DCountFn Min args: 3 Max args: 1 Variadic: false Signature: DCOUNT(arg1: any@scalar) Arg schema: arg1{kinds=any,required=true,shape=scalar,by_ref=false,coercion=None,max=None,repeating=None,default=false} Caps: PURE, REDUCTION [formualizer-docgen:schema:end]
fn name(&self) -> &'static str
fn min_args(&self) -> usize
fn variadic(&self) -> bool
fn arg_schema(&self) -> &'static [ArgSchema]
Source§fn eval<'a, 'b, 'c>(
&self,
args: &'c [ArgumentHandle<'a, 'b>],
ctx: &dyn FunctionContext<'b>,
) -> Result<CalcValue<'b>, ExcelError>
fn eval<'a, 'b, 'c>( &self, args: &'c [ArgumentHandle<'a, 'b>], ctx: &dyn FunctionContext<'b>, ) -> Result<CalcValue<'b>, ExcelError>
The unified evaluation path. Read more
fn namespace(&self) -> &'static str
fn volatile(&self) -> bool
Source§fn aliases(&self) -> &'static [&'static str]
fn aliases(&self) -> &'static [&'static str]
Optional list of additional alias names (case-insensitive) that should resolve to this
function. Default: empty slice. Implementors can override to expose legacy names.
Returned slice must have ’static lifetime (typically a static array reference).
fn function_salt(&self) -> u64
Source§fn eval_reference<'a, 'b, 'c>(
&self,
_args: &'c [ArgumentHandle<'a, 'b>],
_ctx: &dyn FunctionContext<'b>,
) -> Option<Result<ReferenceType, ExcelError>>
fn eval_reference<'a, 'b, 'c>( &self, _args: &'c [ArgumentHandle<'a, 'b>], _ctx: &dyn FunctionContext<'b>, ) -> Option<Result<ReferenceType, ExcelError>>
Optional reference result path. Only called by the interpreter/engine
when the callsite expects a reference (e.g., range combinators, by-ref
argument positions, or spill sources). Read more
Source§fn dispatch<'a, 'b, 'c>(
&self,
args: &'c [ArgumentHandle<'a, 'b>],
ctx: &dyn FunctionContext<'b>,
) -> Result<CalcValue<'b>, ExcelError>
fn dispatch<'a, 'b, 'c>( &self, args: &'c [ArgumentHandle<'a, 'b>], ctx: &dyn FunctionContext<'b>, ) -> Result<CalcValue<'b>, ExcelError>
Dispatch to the unified evaluation path with automatic argument validation.
Auto Trait Implementations§
impl Freeze for DCountFn
impl RefUnwindSafe for DCountFn
impl Send for DCountFn
impl Sync for DCountFn
impl Unpin for DCountFn
impl UnsafeUnpin for DCountFn
impl UnwindSafe for DCountFn
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more