pub struct DSumFn;Trait Implementations§
Source§impl Function for DSumFn
Sums values in a database field for records that match criteria.
impl Function for DSumFn
Sums values in a database field for records that match criteria.
DSUM filters database rows using a criteria range, then adds the selected field values.
§Remarks
- Criteria rows are evaluated with OR semantics; populated criteria columns within one row are ANDed.
fieldresolves by case-insensitive header text or 1-based column index; unknown headers and out-of-range indexes return#VALUE!.- Non-numeric values in the target field are ignored unless they coerce to numbers.
§Examples
title: "Sum revenue for East or West regions"
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: "West"
G3: "East"
formula: "=DSUM(A1:E7, \"Revenue\", G1:G3)"
expected: 415500title: "Sum revenue by field index with numeric criteria"
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: "Units"
G2: ">20"
formula: "=DSUM(A1:E7, 5, G1:G2)"
expected: 488500related:
- DAVERAGE
- DCOUNT
- SUMIFS
faq:
- q: "How are multiple criteria rows interpreted in DSUM?"
a: "Each criteria row is an OR branch, while multiple populated criteria columns in one row are combined with AND."[formualizer-docgen:schema:start] Name: DSUM Type: DSumFn Min args: 3 Max args: 1 Variadic: false Signature: DSUM(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 DSumFn
impl RefUnwindSafe for DSumFn
impl Send for DSumFn
impl Sync for DSumFn
impl Unpin for DSumFn
impl UnsafeUnpin for DSumFn
impl UnwindSafe for DSumFn
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