- Support Home
- Knowledge Base
- Subscriber Management
- Subscriber Profiles
- Calculated Custom Field Use Cases
Calculated Custom Field Use Cases
"Calculated Custom Fields (CCF)" and Calculated Profile Fields (CPF) in Taguchi provide powerful ways to segment and personalize your marketing campaigns based on specific criteria or subscriber behaviors. Below are various use cases that can be implemented. These examples showcase the versatility and utility of CCFs in different scenarios.
Why Use Calculated Custom Fields
- Dynamic Data Segmentation: Automatically categorize subscribers based on behavior, attributes, or interactions.
- Real-time Data Calculation: CCFs are computed at runtime, ensuring up-to-date information.
- Customizable Business Logic: Define custom rules for field calculations using a scripting language or editor.
- Enhanced Targeting and Personalization: Create highly targeted campaigns based on real-time data.
Benefits of Calculated Custom Fields:
- Automation: Update and maintain field values automatically.
- Precision: Enables specific targeting based on real-time data.
- Flexibility: Adaptable to diverse business needs.
- Efficiency: Automates complex data processing tasks.
Refer to this link to find out How to create a custom field
Examples of Calculated Custom Fields:
1. Tag Active Subscribers with a True value
- Use case: Tag subscribers which classifies active customers, i.e. transacted within the last 3 months.
- Target Expression: Purchased last 3 months
- Rule:FUN main() RETURN "True" END
2. Round Robin Allocation Across 4 Groups
- Use case: Evenly split subscribers into four groups (G1–G4) for A/B/n testing, creative variations, or staggered campaign sends. Ideal for marketers running controlled experiments or balancing message load.
- Target Expression: ID is not null
- Rule:FUN main() VAR group = LOAD("group", 0) IF group == 4 THEN VAR newGroup = SAVE("group", 1) ELSE VAR newGroup = SAVE("group", group + 1) END RETURN "G" + STR(newGroup) END
3. 30/30/30/10% Group Split
- Use case: Segment subscribers into four groups (G1–G4) with a 30/30/30/10% distribution—ideal when allocating traffic unevenly across campaign variants (e.g., testing new creative on a smaller group), or when aligning send volumes to team or resource availability.
- Rule:FUN main() VAR split = LOAD("split", 1) SAVE("split", split + 1) IF split == 10 THEN SAVE("split", 1) RETURN "G4" ELIF split >= 7 THEN RETURN "G3" ELIF split >= 4 THEN RETURN "G2" ELSE RETURN "G1" END END
4. Percentage-Based Group Allocation
- Use case: Segment customers with one group containing 5%, and splitting the remaining three (G1 - 32%, G2 - 32%, G3 - 31%, G4 - 5%).
- Rule:FUN main() VAR split = LOAD("split", 1) SAVE("split", split + 1) IF split > 20 THEN SAVE("split", 1) RETURN "G4" ELIF split > 13 THEN RETURN "G3" ELIF split > 6 THEN RETURN "G2" ELSE RETURN "G1" END END
5. A/B Testing Group Assignment
- Use case: Launching a new website and for testing purposes wish to send limited traffic. You'd like the first 50,000 subscribers to a test group and the remaining to a control group for A/B testing.
- Rule:FUN main() VAR group_num = LOAD("group", 0) + 1 VAR saved_group_num = SAVE("group", group_num) IF saved_group_num <= 50000 THEN RETURN 1 ELSE RETURN 2 END END
6. Record Subscriber Opt-In Date
- Use case: Your organisation wants to review and monitor subscriber tenure.
- Rule:FUN main() RETURN CURRENT_DATETIME() END- For date in YYYY-MM-DD format: Replace CURRENT_DATETIME()withCURRENT_DATE().
 
- For date in YYYY-MM-DD format: Replace 
7. Segment by States
- Use case: You sell apparel and would like to segment the database based on the subscriber's climate. Allows for more personalised communications. i.e. display coats to subscribers who live in cooler climates and tees for warmer climates.
- Rule:FUN main() VAR state = $["state"] IF state == "Queensland" OR state == "Northern Territory" THEN RETURN "Northern Australia" ELSE IF state == "Victoria" OR state == "New South Wales" OR state == "Australian Capital Territory" OR state == "Tasmania" OR state == "Western Australia" THEN RETURN "Southern Australia" ELSE RETURN "Other Region" END END
8. Map "State" Based on Postcode
- Use case: Your organisation has not historically collected ‘state’ as a database custom field. Populate the "State" profile field dynamically based on the customer's "postcode" value. For the postcodes that span multiple states, map to the first listed state. (Note: This can be implemented via Calculated Profile Fields (CPF) under Settings > Profile Field & Validation.)
- Target Expression: postcode ilike "%"
- Rule: - FUN main() VAR postcode = $["postcode"] VAR first_digit_str = REPLACE("[0-9]{3}$", REPLACE(" ", postcode, ""), "") # Map postcode ranges to states IF first_digit_str == "1" THEN RETURN "NSW" ELIF first_digit_str == "2" THEN RETURN "ACT" ELIF first_digit_str == "3" THEN RETURN "VIC" ELIF first_digit_str == "4" OR first_digit_str == "9" THEN RETURN "QLD" ELIF first_digit_str == "5" THEN RETURN "SA" ELIF first_digit_str == "6" THEN RETURN "WA" ELIF first_digit_str == "7" THEN RETURN "TAS" ELIF first_digit_str == "8" THEN RETURN "NT" ELSE RETURN "NIL" # Handle unexpected postcodes END END
9-1 Assign Subscribers to Random Groups for Segmentation
- Use case: You are launching a competition and want to stress test the platform before directing full database email traffic. Randomly assign 150,000 subscribers to a test group.
Custom field one:
- Target Expression: (subscribed lists 31 and contactable via email) random 150000
- Rule:FUN main() VAR group = LOAD("group", 0) IF group == 1 THEN VAR newGroup = SAVE("group", 1) ELSE VAR newGroup = SAVE("group", group + 1) END RETURN "G" + STR(newGroup) END
9-2 Assign all Remaining subscribers
Custom field two:
- Target Expression: (subscribed lists 31 and contactable via email and not 'cf:custom field one' ilike "%")
- Rule:FUN main() RETURN "G4" END
10. Convert DOB to Age
- Use case: You are a travel organisation selling flights and therefore have age requirements for infant child tickets, so a quick way to format dates can help detect booking errors. Convert a child’s DOB to age (e.g., "2020-07-07" to "3 years").
- Target Expression: cf:Child1_DOB ilike "%"
- Rule:FUN main() VAR AGE_VALUE = AGE(GET_DATETIME_FROM_ISO8601_STRING($["Child_DOB_value"])) RETURN YEARS(AGE_VALUE) END
11. Track and Calculate the Number of Specific Actions or Events Based on Custom Field
- Use case: You sell pizzas and knowing what products are selling well/poorly could help plan offers. Track and calculate the number of purchases a subscriber has made, where each purchase is recorded as a custom field with a value of "1 or more" indicating the transaction occurred.
- Target Expression: cf:margherita_orders ilike "%" or cf:pepperoni_orders ilike "%" or cf:bbq_chicken_orders ilike "%"
- Rule:  FUN main() VAR purchase1 = INT($["margherita_orders"]) VAR purchase2 = INT($["pepperoni_orders"]) VAR purchase3 = INT($["bbq_chicken_orders"]) RETURN purchase1 + purchase2 + purchase3 END
Additional Use Cases:
Functions for Rule Logic:
- MAKE_E164_FORMAT(country_code, phone_value): Formats a phone number into E164 format using a specified country code (e.g., AU, SG). Requires a country code and phone number field.- MAKE_E164_FORMAT(country_code, phone_number_field)
- GET_DATETIME_FROM_STRING(value, format): Converts a string to a datetime object using the specified format (compatible with Python's strftime/strptime).- GET_DATETIME_FROM_STRING(value, format)
- GET_DATETIME_FROM_ISO8601_STRING(value): Converts an ISO8601 string to a datetime object.- GET_DATETIME_FROM_ISO8601_STRING(value)
- AGE(value): Calculates age from a datetime value relative to the current date.- AGE(GET_DATETIME_FROM_ISO8601_STRING("value"))
- YEARS(value): Returns the number of years from a datetime interval.- YEARS(datetime_value)
- MONTHS(value): Returns the number of months from a datetime interval.- MONTHS(datetime_value)
- DAYS(value): Returns the number of days from a datetime interval.- DAYS(AGE(GET_DATETIME_FROM_ISO8601_STRING("value")))
These examples offer a foundation for using Calculated Custom Fields in various marketing scenarios. Adapt these rules as needed to fit your requirements.
For additional questions or further assistance with Custom Fields, please contact Taguchi Support.
