22QString QgsUniqueValuesAlgorithm::name()
const
24 return QStringLiteral(
"listuniquevalues" );
27QString QgsUniqueValuesAlgorithm::displayName()
const
29 return QObject::tr(
"List unique values" );
32QStringList QgsUniqueValuesAlgorithm::tags()
const
34 return QObject::tr(
"count,unique,values" ).split(
',' );
37QString QgsUniqueValuesAlgorithm::group()
const
39 return QObject::tr(
"Vector analysis" );
42QString QgsUniqueValuesAlgorithm::groupId()
const
44 return QStringLiteral(
"vectoranalysis" );
47QString QgsUniqueValuesAlgorithm::shortHelpString()
const
49 return QObject::tr(
"This algorithm generates a report with information about the unique values found in a given attribute (or attributes) of a vector layer." );
52QString QgsUniqueValuesAlgorithm::shortDescription()
const
54 return QObject::tr(
"Returns list of unique values in given field(s) of a vector layer." );
57QgsUniqueValuesAlgorithm *QgsUniqueValuesAlgorithm::createInstance()
const
59 return new QgsUniqueValuesAlgorithm();
62void QgsUniqueValuesAlgorithm::initAlgorithm(
const QVariantMap & )
67 addParameter(
new QgsProcessingParameterFileDestination( QStringLiteral(
"OUTPUT_HTML_FILE" ), QObject::tr(
"HTML report" ), QObject::tr(
"HTML files (*.html *.htm)" ), QVariant(),
true ) );
74 std::unique_ptr<QgsProcessingFeatureSource> source( parameterAsSource( parameters, QStringLiteral(
"INPUT" ), context ) );
78 const QStringList fieldNames = parameterAsStrings( parameters, QStringLiteral(
"FIELDS" ), context );
79 const QString outputHtml = parameterAsFileOutput( parameters, QStringLiteral(
"OUTPUT_HTML_FILE" ), context );
82 QList<int> fieldIndices;
84 for (
const QString &fieldName : fieldNames )
86 int fieldIndex = source->fields().lookupField( fieldName );
89 feedback->
reportError( QObject::tr(
"Invalid field name %1" ).arg( fieldName ) );
92 fields.
append( source->fields().at( fieldIndex ) );
93 fieldIndices << fieldIndex;
103 QSet<QgsAttributes> values;
104 if ( fieldIndices.size() == 1 )
106 const QSet<QVariant> unique = source->uniqueValues( fieldIndices.at( 0 ) );
107 for (
const QVariant &v : unique )
120 const double step = source->featureCount() > 0 ? 100.0 / source->featureCount() : 0;
130 for (
auto &i : std::as_const( fieldIndices ) )
134 values.insert( attrs );
142 outputs.insert( QStringLiteral(
"TOTAL_VALUES" ), values.size() );
144 QStringList valueList;
145 for (
auto it = values.constBegin(); it != values.constEnd(); ++it )
148 for (
const QVariant &v : std::as_const( *it ) )
150 s.append( v.toString() );
152 valueList.append( s.join(
',' ) );
154 outputs.insert( QStringLiteral(
"UNIQUE_VALUES" ), valueList.join(
';' ) );
158 for (
auto it = values.constBegin(); it != values.constEnd(); ++it )
169 outputs.insert( QStringLiteral(
"OUTPUT" ), dest );
172 if ( !outputHtml.isEmpty() )
174 QFile file( outputHtml );
175 if ( file.open( QIODevice::WriteOnly | QIODevice::Truncate ) )
177 QTextStream out( &file );
178#if QT_VERSION < QT_VERSION_CHECK( 6, 0, 0 )
179 out.setCodec(
"UTF-8" );
181 out << QStringLiteral(
"<html><head><meta http-equiv=\"Content-Type\" content=\"text/html;charset=utf-8\"/></head><body>\n" );
182 out << QObject::tr(
"<p>Total unique values: %1</p>" ).arg( values.size() );
183 out << QObject::tr(
"<p>Unique values:</p>" );
184 out << QStringLiteral(
"<ul>" );
185 for (
auto &v : std::as_const( valueList ) )
187 out << QStringLiteral(
"<li>%1</li>" ).arg( v );
189 out << QStringLiteral(
"</ul></body></html>" );
191 outputs.insert( QStringLiteral(
"OUTPUT_HTML_FILE" ), outputHtml );
@ Vector
Tables (i.e. vector layers with or without geometry). When used for a sink this indicates the sink ha...
@ NoGeometry
Geometry is not required. It may still be returned if e.g. required for a filter condition.
Represents a coordinate reference system (CRS).
Wrapper for iterator of features from vector data provider or vector layer.
bool nextFeature(QgsFeature &f)
Fetch next feature and stores in f, returns true on success.
Wraps a request for features to a vector layer (or directly its vector data provider).
QgsFeatureRequest & setFlags(Qgis::FeatureRequestFlags flags)
Sets flags that affect how features will be fetched.
QgsFeatureRequest & setSubsetOfAttributes(const QgsAttributeList &attrs)
Set a subset of attributes that will be fetched.
@ FastInsert
Use faster inserts, at the cost of updating the passed features to reflect changes made at the provid...
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
void setAttributes(const QgsAttributes &attrs)
Sets the feature's attributes.
Q_INVOKABLE QVariant attribute(const QString &name) const
Lookup attribute value by attribute name.
bool isCanceled() const
Tells whether the operation has been canceled already.
void setProgress(double progress)
Sets the current progress for the feedback object.
Container of fields for a vector layer.
bool append(const QgsField &field, Qgis::FieldOrigin origin=Qgis::FieldOrigin::Provider, int originIndex=-1)
Appends a field.
Contains information about the context in which a processing algorithm is executed.
Custom exception class for processing related exceptions.
Base class for providing feedback from a processing algorithm.
virtual void reportError(const QString &error, bool fatalError=false)
Reports that the algorithm encountered an error while executing.
A numeric output for processing algorithms.
A string output for processing algorithms.
A feature sink output for processing algorithms.
An input feature source (such as vector layers) parameter for processing algorithms.
A vector layer or feature source field parameter for processing algorithms.
A generic file based destination parameter, for specifying the destination path for a file (non-map l...