Aspose::Words::VariableCollection::get_Count method
Contents
[
Hide
]VariableCollection::get_Count method
Gets the number of elements contained in the collection.
int32_t Aspose::Words::VariableCollection::get_Count()
Examples
Shows how to work with a document’s variable collection.
auto doc = System::MakeObject<Aspose::Words::Document>();
System::SharedPtr<Aspose::Words::VariableCollection> variables = doc->get_Variables();
// Every document has a collection of key/value pair variables, which we can add items to.
variables->Add(u"Home address", u"123 Main St.");
variables->Add(u"City", u"London");
variables->Add(u"Bedrooms", u"3");
ASSERT_EQ(3, variables->get_Count());
// We can display the values of variables in the document body using DOCVARIABLE fields.
auto builder = System::MakeObject<Aspose::Words::DocumentBuilder>(doc);
auto field = System::ExplicitCast<Aspose::Words::Fields::FieldDocVariable>(builder->InsertField(Aspose::Words::Fields::FieldType::FieldDocVariable, true));
field->set_VariableName(u"Home address");
field->Update();
ASSERT_EQ(u"123 Main St.", field->get_Result());
// Assigning values to existing keys will update them.
variables->Add(u"Home address", u"456 Queen St.");
// We will then have to update DOCVARIABLE fields to ensure they display an up-to-date value.
ASSERT_EQ(u"123 Main St.", field->get_Result());
field->Update();
ASSERT_EQ(u"456 Queen St.", field->get_Result());
// Verify that the document variables with a certain name or value exist.
ASSERT_TRUE(variables->Contains(u"City"));
ASSERT_TRUE(variables->LINQ_Any(static_cast<System::Func<System::Collections::Generic::KeyValuePair<System::String, System::String>, bool>>(static_cast<std::function<bool(System::Collections::Generic::KeyValuePair<System::String, System::String> v)>>([](System::Collections::Generic::KeyValuePair<System::String, System::String> v) -> bool
{
    return v.get_Value() == u"London";
}))));
// The collection of variables automatically sorts variables alphabetically by name.
ASSERT_EQ(0, variables->IndexOfKey(u"Bedrooms"));
ASSERT_EQ(1, variables->IndexOfKey(u"City"));
ASSERT_EQ(2, variables->IndexOfKey(u"Home address"));
ASSERT_EQ(u"3", variables->idx_get(0));
ASSERT_EQ(u"London", variables->idx_get(u"City"));
// Enumerate over the collection of variables.
{
    System::SharedPtr<System::Collections::Generic::IEnumerator<System::Collections::Generic::KeyValuePair<System::String, System::String>>> enumerator = doc->get_Variables()->GetEnumerator();
    while (enumerator->MoveNext())
    {
        std::cout << System::String::Format(u"Name: {0}, Value: {1}", enumerator->get_Current().get_Key(), enumerator->get_Current().get_Value()) << std::endl;
    }
}
// Below are three ways of removing document variables from a collection.
// 1 -  By name:
variables->Remove(u"City");
ASSERT_FALSE(variables->Contains(u"City"));
// 2 -  By index:
variables->RemoveAt(1);
ASSERT_FALSE(variables->Contains(u"Home address"));
// 3 -  Clear the whole collection at once:
variables->Clear();
ASSERT_EQ(0, variables->get_Count());
See Also
- Class VariableCollection
- Namespace Aspose::Words
- Library Aspose.Words for C++