mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-26 00:04:03 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			411 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			411 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /************************************************************************
 | |
|  * This file has been generated automatically from                      *
 | |
|  *                                                                      *
 | |
|  * src/core/qgsfield.h                                                  *
 | |
|  *                                                                      *
 | |
|  * Do not edit manually ! Edit header and run scripts/sipify.pl again   *
 | |
|  ************************************************************************/
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| class QgsField
 | |
| {
 | |
| %Docstring(signature="appended")
 | |
| Encapsulate a field in an attribute table or data source.
 | |
| 
 | |
| :py:class:`QgsField` stores metadata about an attribute field, including name, type
 | |
| length, and if applicable, precision.
 | |
| 
 | |
| .. note::
 | |
| 
 | |
|    :py:class:`QgsField` objects are implicitly shared.
 | |
| %End
 | |
| 
 | |
| %TypeHeaderCode
 | |
| #include "qgsfield.h"
 | |
| %End
 | |
|   public:
 | |
|     static const QMetaObject staticMetaObject;
 | |
| 
 | |
|   public:
 | |
| 
 | |
| 
 | |
|     QgsField( const QString &name = QString(),
 | |
|               QVariant::Type type = QVariant::Invalid,
 | |
|               const QString &typeName = QString(),
 | |
|               int len = 0,
 | |
|               int prec = 0,
 | |
|               const QString &comment = QString(),
 | |
|               QVariant::Type subType = QVariant::Invalid );
 | |
| %Docstring
 | |
| Constructor. Constructs a new QgsField object.
 | |
| 
 | |
| :param name: Field name
 | |
| :param type: Field variant type, currently supported: String / Int / Double
 | |
| :param typeName: Field type (e.g., char, varchar, text, int, serial, double).
 | |
|                  Field types are usually unique to the source and are stored exactly
 | |
|                  as returned from the data store.
 | |
| :param len: Field length
 | |
| :param prec: Field precision. Usually decimal places but may also be
 | |
|              used in conjunction with other fields types (e.g., variable character fields)
 | |
| :param comment: Comment for the field
 | |
| :param subType: If the field is a collection, its element's type. When
 | |
|                 all the elements don't need to have the same type, leave
 | |
|                 this to QVariant.Invalid.
 | |
| %End
 | |
| 
 | |
|     QgsField( const QgsField &other );
 | |
| %Docstring
 | |
| Copy constructor
 | |
| %End
 | |
| 
 | |
| 
 | |
|     virtual ~QgsField();
 | |
| 
 | |
|     bool operator==( const QgsField &other ) const;
 | |
|     bool operator!=( const QgsField &other ) const;
 | |
| 
 | |
|     QString name() const;
 | |
| %Docstring
 | |
| Returns the name of the field.
 | |
| 
 | |
| .. seealso:: :py:func:`setName`
 | |
| 
 | |
| .. seealso:: :py:func:`displayName`
 | |
| %End
 | |
| 
 | |
|     QString displayName() const;
 | |
| %Docstring
 | |
| Returns the name to use when displaying this field. This will be the
 | |
| field alias if set, otherwise the field name.
 | |
| 
 | |
| .. seealso:: :py:func:`name`
 | |
| 
 | |
| .. seealso:: :py:func:`alias`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     QString displayNameWithAlias() const;
 | |
| %Docstring
 | |
| Returns the name to use when displaying this field and adds the alias in parenthesis if it is defined.
 | |
| 
 | |
| This will be used when working close to the data structure (i.e. building expressions and queries),
 | |
| when the real field name must be shown but the alias is also useful to understand what the field
 | |
| represents.
 | |
| 
 | |
| .. seealso:: :py:func:`name`
 | |
| 
 | |
| .. seealso:: :py:func:`alias`
 | |
| 
 | |
| .. versionadded:: 3.12
 | |
| %End
 | |
| 
 | |
| 
 | |
|     QString displayType( bool showConstraints = false ) const;
 | |
| %Docstring
 | |
| Returns the type to use when displaying this field, including the length and precision of the datatype if applicable.
 | |
| 
 | |
| This will be used when the full datatype with details has to displayed to the user.
 | |
| 
 | |
| .. seealso:: :py:func:`type`
 | |
| 
 | |
| .. versionadded:: 3.14
 | |
| %End
 | |
| 
 | |
|     QVariant::Type type() const;
 | |
| %Docstring
 | |
| Gets variant type of the field as it will be retrieved from data source
 | |
| %End
 | |
| 
 | |
|     QVariant::Type subType() const;
 | |
| %Docstring
 | |
| If the field is a collection, gets its element's type.
 | |
| When all the elements don't need to have the same type, this returns
 | |
| QVariant.Invalid.
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     QString typeName() const;
 | |
| %Docstring
 | |
| Gets the field type. Field types vary depending on the data source. Examples
 | |
| are char, int, double, blob, geometry, etc. The type is stored exactly as
 | |
| the data store reports it, with no attempt to standardize the value.
 | |
| 
 | |
| :return: QString containing the field type
 | |
| %End
 | |
| 
 | |
|     int length() const;
 | |
| %Docstring
 | |
| Gets the length of the field.
 | |
| 
 | |
| :return: int containing the length of the field
 | |
| %End
 | |
| 
 | |
|     int precision() const;
 | |
| %Docstring
 | |
| Gets the precision of the field. Not all field types have a related precision.
 | |
| 
 | |
| :return: int containing the precision or zero if not applicable to the field type.
 | |
| %End
 | |
| 
 | |
|     QString comment() const;
 | |
| %Docstring
 | |
| Returns the field comment
 | |
| %End
 | |
| 
 | |
|     bool isNumeric() const;
 | |
| %Docstring
 | |
| Returns if this field is numeric. Any integer or floating point type
 | |
| will return ``True`` for this.
 | |
| 
 | |
| .. versionadded:: 2.18
 | |
| %End
 | |
| 
 | |
|     bool isDateOrTime() const;
 | |
| %Docstring
 | |
| Returns if this field is a date and/or time type.
 | |
| 
 | |
| .. versionadded:: 3.6
 | |
| %End
 | |
| 
 | |
|     void setName( const QString &name );
 | |
| %Docstring
 | |
| Set the field name.
 | |
| 
 | |
| :param name: Name of the field
 | |
| %End
 | |
| 
 | |
|     void setType( QVariant::Type type );
 | |
| %Docstring
 | |
| Set variant type.
 | |
| %End
 | |
| 
 | |
|     void setSubType( QVariant::Type subType );
 | |
| %Docstring
 | |
| If the field is a collection, set its element's type.
 | |
| When all the elements don't need to have the same type, set this to
 | |
| QVariant.Invalid.
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     void setTypeName( const QString &typeName );
 | |
| %Docstring
 | |
| Set the field type.
 | |
| 
 | |
| :param typeName: Field type
 | |
| %End
 | |
| 
 | |
|     void setLength( int len );
 | |
| %Docstring
 | |
| Set the field length.
 | |
| 
 | |
| :param len: Length of the field
 | |
| %End
 | |
| 
 | |
|     void setPrecision( int precision );
 | |
| %Docstring
 | |
| Set the field precision.
 | |
| 
 | |
| :param precision: Precision of the field
 | |
| %End
 | |
| 
 | |
|     void setComment( const QString &comment );
 | |
| %Docstring
 | |
| Set the field comment
 | |
| %End
 | |
| 
 | |
|     QgsDefaultValue defaultValueDefinition() const;
 | |
| %Docstring
 | |
| Returns the expression used when calculating the default value for the field.
 | |
| 
 | |
| :return: expression evaluated when calculating default values for field, or an
 | |
|          empty string if no default is set
 | |
| 
 | |
| .. seealso:: :py:func:`setDefaultValueDefinition`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     void setDefaultValueDefinition( const QgsDefaultValue &defaultValueDefinition );
 | |
| %Docstring
 | |
| Sets an expression to use when calculating the default value for the field.
 | |
| 
 | |
| :param defaultValueDefinition: expression to evaluate when calculating default values for field. Pass
 | |
|                                a default constructed :py:class:`QgsDefaultValue`() to reset.
 | |
| 
 | |
| .. seealso:: :py:func:`defaultValueDefinition`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     const QgsFieldConstraints &constraints() const;
 | |
| %Docstring
 | |
| Returns constraints which are present for the field.
 | |
| 
 | |
| .. seealso:: :py:func:`setConstraints`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     void setConstraints( const QgsFieldConstraints &constraints );
 | |
| %Docstring
 | |
| Sets constraints which are present for the field.
 | |
| 
 | |
| .. seealso:: :py:func:`constraints`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     QString alias() const;
 | |
| %Docstring
 | |
| Returns the alias for the field (the friendly displayed name of the field ),
 | |
| or an empty string if there is no alias.
 | |
| 
 | |
| .. seealso:: :py:func:`setAlias`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
|     void setAlias( const QString &alias );
 | |
| %Docstring
 | |
| Sets the alias for the field (the friendly displayed name of the field ).
 | |
| 
 | |
| :param alias: field alias, or empty string to remove an existing alias
 | |
| 
 | |
| .. seealso:: :py:func:`alias`
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
| 
 | |
| 
 | |
|     QString displayString( const QVariant &v ) const;
 | |
| %Docstring
 | |
| Formats string for display
 | |
| %End
 | |
| 
 | |
| 
 | |
| 
 | |
|     bool convertCompatible( QVariant &v ) const;
 | |
| %Docstring
 | |
| Converts the provided variant to a compatible format
 | |
| 
 | |
| :param v: The value to convert
 | |
| 
 | |
| :raises ValueError: if the value could not be converted to a compatible format
 | |
| %End
 | |
| %MethodCode
 | |
|     PyObject *sipParseErr = NULL;
 | |
| 
 | |
|     {
 | |
|       QVariant *a0;
 | |
|       int a0State = 0;
 | |
|       const QgsField *sipCpp;
 | |
| 
 | |
|       if ( sipParseArgs( &sipParseErr, sipArgs, "BJ1", &sipSelf, sipType_QgsField, &sipCpp, sipType_QVariant, &a0, &a0State ) )
 | |
|       {
 | |
|         bool sipRes;
 | |
|         QString errorMessage;
 | |
| 
 | |
|         Py_BEGIN_ALLOW_THREADS
 | |
|         try
 | |
|         {
 | |
|           sipRes = sipCpp->convertCompatible( *a0, &errorMessage );
 | |
|         }
 | |
|         catch ( ... )
 | |
|         {
 | |
|           Py_BLOCK_THREADS
 | |
| 
 | |
|           sipReleaseType( a0, sipType_QVariant, a0State );
 | |
|           sipRaiseUnknownException();
 | |
|           return NULL;
 | |
|         }
 | |
| 
 | |
|         Py_END_ALLOW_THREADS
 | |
| 
 | |
|         if ( !sipRes )
 | |
|         {
 | |
|           PyErr_SetString( PyExc_ValueError,
 | |
|                            QString( "Value could not be converted to field type %1: %2" ).arg( QMetaType::typeName( sipCpp->type() ), errorMessage ).toUtf8().constData() );
 | |
|           sipIsErr = 1;
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|           PyObject *res = sipConvertFromType( a0, sipType_QVariant, NULL );
 | |
|           sipReleaseType( a0, sipType_QVariant, a0State );
 | |
|           return res;
 | |
|         }
 | |
|       }
 | |
|       else
 | |
|       {
 | |
|         // Raise an exception if the arguments couldn't be parsed.
 | |
|         sipNoMethod( sipParseErr, sipName_QgsField, sipName_convertCompatible, doc_QgsField_convertCompatible );
 | |
| 
 | |
|         return nullptr;
 | |
|       }
 | |
|     }
 | |
| 
 | |
| %End
 | |
| 
 | |
|     operator QVariant() const;
 | |
| 
 | |
|     void setEditorWidgetSetup( const QgsEditorWidgetSetup &v );
 | |
| %Docstring
 | |
| Set the editor widget setup for the field.
 | |
| 
 | |
| :param v: The value to set
 | |
| %End
 | |
| 
 | |
|     QgsEditorWidgetSetup editorWidgetSetup() const;
 | |
| %Docstring
 | |
| Gets the editor widget setup for the field.
 | |
| 
 | |
| Defaults may be set by the provider and can be overridden
 | |
| by manual field configuration.
 | |
| 
 | |
| :return: the value
 | |
| %End
 | |
| 
 | |
|     void setReadOnly( bool readOnly );
 | |
| %Docstring
 | |
| Make field read-only if ``readOnly`` is set to true. This is the case for
 | |
| providers which support generated fields for instance.
 | |
| 
 | |
| .. versionadded:: 3.18
 | |
| %End
 | |
| 
 | |
|     bool isReadOnly() const;
 | |
| %Docstring
 | |
| Returns ``True`` if this field is a read-only field. This is the case for
 | |
| providers which support generated fields for instance.
 | |
| 
 | |
| .. versionadded:: 3.18
 | |
| %End
 | |
| 
 | |
|     SIP_PYOBJECT __repr__();
 | |
| %MethodCode
 | |
|     QString str = QStringLiteral( "<QgsField: %1 (%2)>" ).arg( sipCpp->name() ).arg( sipCpp->typeName() );
 | |
|     sipRes = PyUnicode_FromString( str.toUtf8().constData() );
 | |
| %End
 | |
| 
 | |
| }; // class QgsField
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| /************************************************************************
 | |
|  * This file has been generated automatically from                      *
 | |
|  *                                                                      *
 | |
|  * src/core/qgsfield.h                                                  *
 | |
|  *                                                                      *
 | |
|  * Do not edit manually ! Edit header and run scripts/sipify.pl again   *
 | |
|  ************************************************************************/
 |