Skip to main content

A singleton Nil object to represent missing values when None is a valid data value

Project description

NilType

Codecov PyPI PyPI - Downloads Python Version

NilType is a Python package that provides a Nil singleton object to represent a null or missing value in situations where None is a valid data value and cannot be used to signify the absence of data. This is especially useful in data models or functions where None might be a meaningful value, and a distinct placeholder is needed to indicate 'no value' or 'missing data'.

Installation

Install niltype using pip:

pip3 install niltype

Introduction

In Python, None is often used to represent the absence of a value. However, there are cases where None is a valid and meaningful value within your data model. In such situations, you need a different sentinel value to represent 'no value' or 'missing data'. This is where NilType comes into play by providing a Nil object.

Usage

Importing Nil

First, import Nil from the niltype package:

from niltype import Nil

Checking for Nil

You can check if a variable is Nil using the is operator:

if x is Nil:
    # x is missing or undefined
    pass

This check will only be True if x is exactly Nil.

Example Usage

Here's an example of using Nil to provide a default value in a function:

from niltype import Nil

def get(dictionary, key, default=Nil):
    try:
        return dictionary[key]
    except KeyError:
        if default is not Nil:
            return default
        raise

# Example usages:
get({}, 'key')            # Raises KeyError because no default is provided
get({}, 'key', None)      # Returns None
get({}, 'key', 'default') # Returns 'default'

In this example, the get function behaves similarly to dict.get(), but it raises a KeyError if the key is not found and no default value is provided. By using Nil as the default default value, you can distinguish between when a default has been provided (None or any other value) and when it hasn't.

Nil and Truthiness

The Nil object evaluates to False in boolean contexts:

if not Nil:
    print("Nil is Falsey")  # This will print

Using Nil in Type Annotations

You can use the Nilable type to indicate that a variable can be either a specific type or Nil:

from niltype import Nilable

def process(value: Nilable[int]) -> None:
    if value is Nil:
        print("Value is missing")
    else:
        print(f"Value is {value}")

process(10)    # Output: Value is 10
process(Nil)   # Output: Value is missing

The Nilable type is a type alias that allows for a value of type _T or NilType, providing better type hints and checks when using type annotations.

When to Use Nil

Use Nil when you need a unique sentinel value to represent missing or undefined data, especially in the following scenarios:

  • Default Parameters: Distinguish between an explicit None and an unspecified parameter.
  • Data Models: When None is a valid value within your data model, and you need to represent the absence of a value.
  • Optional Values: Clearly indicate optional values without overloading None.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

niltype-1.0.2.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

niltype-1.0.2-py3-none-any.whl (5.3 kB view details)

Uploaded Python 3

File details

Details for the file niltype-1.0.2.tar.gz.

File metadata

  • Download URL: niltype-1.0.2.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for niltype-1.0.2.tar.gz
Algorithm Hash digest
SHA256 82bf705a898552467a393a95f3c750d82cd7c9361705c79f4cf416aeaa50b817
MD5 e91565b29d254bd1083d8431fb531bad
BLAKE2b-256 9c33ce45c90efcf7f951de4fb1e6032fcb5447b1796c951d86e33324fcff2491

See more details on using hashes here.

File details

Details for the file niltype-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: niltype-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 5.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for niltype-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d5a26b50bb212689e3812a5010e8294d16bd7a179dbd051418ee878bad549754
MD5 f88d03888334cbe1fd35a166308066ff
BLAKE2b-256 41d2d3dee14b063ce2ce641a5f6d40b3537622373678c9db9ccbe67d15029b13

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page