snowflake.snowpark.udtf.UDTFRegistration.register¶
- UDTFRegistration.register(handler: Type, output_schema: Union[StructType, Iterable[str]], input_types: Optional[List[DataType]] = None, name: Optional[Union[str, Iterable[str]]] = None, is_permanent: bool = False, stage_location: Optional[str] = None, imports: Optional[List[Union[str, Tuple[str, str]]]] = None, packages: Optional[List[Union[str, module]]] = None, replace: bool = False, if_not_exists: bool = False, parallel: int = 4, strict: bool = False, secure: bool = False, *, statement_params: Optional[Dict[str, str]] = None) UserDefinedTableFunction[source]¶
- Registers a Python class as a Snowflake Python UDTF and returns the UDTF. The usage, input arguments, and return value of this method are the same as they are for - udtf(), but- register()cannot be used as a decorator. See examples in- UDTFRegistration.- Parameters:
- handler – A Python class used for creating the UDTF. 
- output_schema – A list of column names, or a - StructTypeinstance that represents the table function’s columns. If a list of column names is provided, the- processmethod of the handler class must have a return type hint to indicate the output schema data types.
- input_types – A list of - DataTyperepresenting the input data types of the UDTF. Optional if type hints are provided.
- name – A string or list of strings that specify the name or fully-qualified object identifier (database name, schema name, and function name) for the UDTF in Snowflake. If it is not provided, a name will be automatically generated for the UDTF. A name must be specified when - is_permanentis- True.
- is_permanent – Whether to create a permanent UDTF. The default is - False. If it is- True, a valid- stage_locationmust be provided.
- stage_location – The stage location where the Python file for the UDTF and its dependencies should be uploaded. The stage location must be specified when - is_permanentis- True, and it will be ignored when- is_permanentis- False. It can be any stage other than temporary stages and external stages.
- imports – A list of imports that only apply to this UDTF. You can use a string to represent a file path (similar to the - pathargument in- add_import()) in this list, or a tuple of two strings to represent a file path and an import path (similar to the- import_pathargument in- add_import()). These UDTF-level imports will override the session-level imports added by- add_import().
- packages – A list of packages that only apply to this UDTF. These UDTF-level packages will override the session-level packages added by - add_packages()and- add_requirements(). To use Python packages that are not available in Snowflake, refer to- custom_package_usage_config().
- replace – Whether to replace a UDTF that already was registered. The default is - False. If it is- False, attempting to register a UDTF with a name that already exists results in a- SnowparkSQLExceptionexception being thrown. If it is- True, an existing UDTF with the same name is overwritten.
- if_not_exists – Whether to skip creation of a UDTF when one with the same signature already exists. The default is - False.- if_not_existsand- replaceare mutually exclusive and a- ValueErroris raised when both are set. If it is- Trueand a UDTF with the same signature exists, the UDTF creation is skipped.
- session – Use this session to register the UDTF. If it’s not specified, the session that you created before calling this function will be used. You need to specify this parameter if you have created multiple sessions before calling this method. 
- parallel – The number of threads to use for uploading UDTF files with the PUT command. The default value is 4 and supported values are from 1 to 99. Increasing the number of threads can improve performance when uploading large UDTF files. 
- strict – Whether the created UDTF is strict. A strict UDTF will not invoke the UDTF if any input is null. Instead, a null value will always be returned for that row. Note that the UDTF might still return null for non-null inputs. 
- secure – Whether the created UDTF is secure. For more information about secure functions, see Secure UDFs. 
- statement_params – Dictionary of statement level parameters to be set while executing this action. 
 
 - See also