Skip to main content

How to find if a property in a custom object has a NULL NoteProperty

This was a bit of a different problem.  How to find if a property in a custom object has a NULL value.  The client had a collection of objects that they gathered from their environment with PowerShell.  They needed a way to find out if any of the NoteProperties had a NULL value.  I created the function below.  You send it the collection of objects you are interested in probing for a NULL property value and it will return the index number of the object in the collection that has one.

 

Function Find-NullProperty

{

    [cmdletbinding(HelpUri="http://get-help-jason-yoder.blogspot.com/2012/10/find-nullproperty.html")]

    Param (

        [Parameter(Mandatory=$True)]$Object

    )

    # Check to see if an object has any NULL values in

    # its properties.

 

    # Create an object to output to the calling statement.

    $Output = @()

 

    # Index number to return for to denote the instance of an object

    # (should multiple instances be sent) that the Null value if found

    # in.

    $Index = -1

 

    # Extract the names of the properties of the object.

    $PropNames = (($Object | GM) |

      Where {$_.MemberType -eq "NoteProperty"} |

      Select-Object -Property Name).Name

 

    #Cycle through each object

    ForEach ($Obj in $Object)

    {

        # Increment the Index.

        $Index++

 

        # Set to $True is a $Null value

        #is found in a property.

        $NullFound = $False

 

        ForEach ($Prop in $PropNames)

        {     

            If ($Obj.$Prop -contains $Null)

            {

                $NullFound = $True

            }    

        }

        If ($NullFound)

        {

            # Create the object to be returned.

            $Obj = New-Object -TypeName PSObject

           

            # Add object members

            $Obj | Add-Member `

                    -MemberType NoteProperty `

                    -Name "Index" `

                    -Value $Index

           

            # Send the object to the output array.

            $Output += $Obj 

        }

    }

    Write-Output $Output

<#

.SYNOPSIS

Indicates if an object has a property that is $NULL

 

.DESCRIPTION

Search through a collection of custom objects and returns the index

number of any instance that has a $NULL value in a NoteProperty

 

.PARAMETER Object

The Object, or collection of objects that may contain a NULL value

in a note property.

 

.EXAMPLE

Find-NullProperty $Object

 

 Index

 -----

     1

     2

 

Returns the index number of instance of a collection of object in which

a NoteProperty has a NULL value.

 

.NOTES

Provided without warranty or support.

Author: Jason Yoder.

#>

}

 

Comments

Popular posts from this blog

How to list all the AD LDS instances on a server

AD LDS allows you to provide directory services to applications that are free of the confines of Active Directory.  To list all the AD LDS instances on a server, follow this procedure: Log into the server in question Open a command prompt. Type dsdbutil and press Enter Type List Instances and press Enter . You will receive a list of the instance name, both the LDAP and SSL port numbers, the location of the database, and its status.

How to run GPResult on a remote client with PowerShell

In the past, to run the GPResult command, you would need to either physically visit this client, have the user do it, or use and RDP connection.  In all cases, this will disrupt the user.  First, you need PowerShell remoting enabled on the target machine.  You can do this via Group Policy . Open PowerShell and type this command. Invoke-Command –ScriptBlock {GPResult /r} –ComputerName <ComputerName> Replace <ComputerName> with the name of the target.  Remember, the target needs to be online and accessible to you.

Error icon when creating a GPO Preference drive map

You may not have an error at all.  Take a look at the drive mapping below. The red triangle is what threw us off.  It is not an error.  It is simply a color representation of the Replace option of the Action field in the properties of the drive mappings. Create action This give you a green triangle. The Create action creates a new mapped drive for users. Replace Action The Replace action gives you a red triangle.  This action will delete and recreate mapped drives for users. The net result of the Replace action is to overwrite all existing settings associated with the mapped drive. If the drive mapping does not exist, then the Replace action creates a new drive mapping. Update Action The Update action will have a yellow triangle. Update will modify settings of an existing mapped drive for users. This action differs from Replace in that it only updates settings defined within the preference item. All other settings remain as configured on the ma...