Select to view content in your preferred language

Attribute rule arcade statement

2228
11
Jump to solution
08-27-2024 01:33 PM
EricBregant2
Occasional Contributor

Hello! I am working on an attribute rule that will concatenate 6 fields that make up a street address to create a full address. The problem is that 2 of the fields are not always populated with a value. They will either be null or empty.

In the image below, you can see my 6 fields (ST_NUM, DIRPRE, FEANME, FEATYP, DIRSUF and Unit (LV_APT)

Screenshot 2024-08-27 132256.jpg

If I do a simple concatenate of those fields, the result will leave spaces at the end of the full address. I know this is because of there not always being a value in DIRSUF or LV_APT.

I have been working on the below code, but I know I am missing some parts. Any ideas or anyone know a better way?

// List the fields to combine
var parts = [$feature.ST_NUM, $feature.DIRPRE, $feature.FEANME, $feature.FEATYP, $feature.DIRSUF, $feature.LV_APT];

// Loop through the address parts, if not null or empty add them to a new array
var filteredparts = [];
for (var i in parts) {
    var value = parts[i];
    if (IsEmpty(value)) continue;
    filteredparts[Count(filteredparts)] = value
}

// Concatenate with a space
return Concatenate(filteredparts, " ");

0 Kudos
1 Solution

Accepted Solutions
EricBregant2
Occasional Contributor

// List the fields to combine
var parts = [$feature.ST_NUM, $feature.DIRPRE, $feature.FEANME, $feature.FEATYP, $feature.LV_APT];

// Function to check if a value is null or empty
function IsNullOrEmpty(value) {
return value == null || value == "";
}

// Loop through the address parts, if not null or empty add them to a new array
var filteredparts = [];
for (var i in parts) {
var value = parts[i];

// Add '#' before LV_APT if it's not null or empty
if (i == 4 && !IsNullOrEmpty(value)) {
value = "#" + value;
}

if (IsNullOrEmpty(value)) continue;
Push(filteredparts, value); // Use Push to add elements
}

// Concatenate with a space
var finaladdress = Concatenate(filteredparts, " ");
return finaladdress;

View solution in original post

0 Kudos
11 Replies
Brian_McLeer
Frequent Contributor

I think you have to add the "" function to check for if a part is empty. 

// List the fields to combine
var parts = [$feature.ST_NUM, $feature.DIRPRE, $feature.FEANME, $feature.FEATYP, $feature.DIRSUF, $feature.LV_APT];

// Function to check if a value is null or empty
function IsNullOrEmpty(value) {
    return value == null || value == "";
}

// Loop through the address parts, if not null or empty add them to a new array
var filteredparts = [];
for (var i in parts) {
    var value = parts[i];
    if (IsNullOrEmpty(value)) continue;
    filteredparts[Count(filteredparts)] = value;
}

// Concatenate with a space
return Concatenate(filteredparts, " ");
0 Kudos
EricBregant2
Occasional Contributor

Thanks @Brian_McLeer 

0 Kudos
MikeMillerGIS
Esri Frequent Contributor
EricBregant2
Occasional Contributor

I found this as well

var fullName

if(IsEmpty($feature.ST_NUM)==false){
fullName += $feature.ST_NUM + " "
}
if(IsEmpty($feature.DIRPRE)==false){
fullName += $feature.DIRPRE + " "
}
if(IsEmpty($feature.FEANME)==false){
fullName += $feature.FEANME + " "
}
if(IsEmpty($feature.FEATYP)==false){
fullName += $feature.FEATYP + " "
}
if(IsEmpty($feature.DIRSUF)==false){
fullName += $feature.DIRSUF + " "
}
if(IsEmpty($feature.LV_APT)==false){
fullName += $feature.LV_APT + " "
}

return fullName

0 Kudos
MikeMillerGIS
Esri Frequent Contributor

Here is how we do it

 

function not_empty(x) {
  return !IsEmpty(x);
}
return Concatenate(Filter(['a', 'b', '', null,'c'], not_empty), '-');

 

 

returns

 "a-b-c" 

MikeMillerGIS
Esri Frequent Contributor

If you want to handle "  ", then change not_empty to

 

 

function not_empty(x) {
  if (TypeOf(x) == 'String'){
    x = Trim(x)
  }
  return !IsEmpty(x);

 

 

TedHoward2
Esri Contributor

You may need to adapt your code filter out strings with spaces. 

IsEmpty(null) // true
IsEmpty("") // true
IsEmpty(" ") // false

 

EricBregant2
Occasional Contributor

I got the below code to do everything I want except to add an "#" before the unit number ($feature.LV_APT).

Any ideas?

 

// List the fields to combine
var parts = [$feature.ST_NUM, $feature.DIRPRE, $feature.FEANME, $feature.FEATYP, $feature.LV_APT];

// Function to check if a value is null or empty
function IsNullOrEmpty(value) {
return value == null || value == "";
}

// Loop through the address parts, if not null or empty add them to a new array
var filteredparts = [];
for (var i in parts) {
var value = parts[i];
if (IsNullOrEmpty(value)) continue;
Push(filteredparts, value); // Use Push to add elements
}

// Concatenate with a space
var finaladdress = Concatenate(filteredparts, " ")
return finaladdress;

 

0 Kudos
EricBregant2
Occasional Contributor

// List the fields to combine
var parts = [$feature.ST_NUM, $feature.DIRPRE, $feature.FEANME, $feature.FEATYP, $feature.LV_APT];

// Function to check if a value is null or empty
function IsNullOrEmpty(value) {
return value == null || value == "";
}

// Loop through the address parts, if not null or empty add them to a new array
var filteredparts = [];
for (var i in parts) {
var value = parts[i];

// Add '#' before LV_APT if it's not null or empty
if (i == 4 && !IsNullOrEmpty(value)) {
value = "#" + value;
}

if (IsNullOrEmpty(value)) continue;
Push(filteredparts, value); // Use Push to add elements
}

// Concatenate with a space
var finaladdress = Concatenate(filteredparts, " ");
return finaladdress;

0 Kudos