24QString QgsExtractBinaryFieldAlgorithm::name()
const
26 return QStringLiteral(
"extractbinary" );
29QString QgsExtractBinaryFieldAlgorithm::displayName()
const
31 return QObject::tr(
"Extract binary field" );
34QString QgsExtractBinaryFieldAlgorithm::shortHelpString()
const
36 return QObject::tr(
"This algorithm extracts contents from a binary field, saving them to individual files.\n\n"
37 "Filenames can be generated using values taken from "
38 "an attribute in the source table or based on a more complex expression." );
41QString QgsExtractBinaryFieldAlgorithm::shortDescription()
const
43 return QObject::tr(
"Extracts contents from a binary field, saving them to individual files." );
46QStringList QgsExtractBinaryFieldAlgorithm::tags()
const
48 return QObject::tr(
"blob,binaries,save,file,contents,field,column" ).split(
',' );
51QString QgsExtractBinaryFieldAlgorithm::group()
const
53 return QObject::tr(
"Vector table" );
56QString QgsExtractBinaryFieldAlgorithm::groupId()
const
58 return QStringLiteral(
"vectortable" );
61QgsExtractBinaryFieldAlgorithm *QgsExtractBinaryFieldAlgorithm::createInstance()
const
63 return new QgsExtractBinaryFieldAlgorithm();
66void QgsExtractBinaryFieldAlgorithm::initAlgorithm(
const QVariantMap & )
79 std::unique_ptr<QgsProcessingFeatureSource> input( parameterAsSource( parameters, QStringLiteral(
"INPUT" ), context ) );
83 const QString fieldName = parameterAsString( parameters, QStringLiteral(
"FIELD" ), context );
84 const int fieldIndex = input->fields().lookupField( fieldName );
88 const QString folder = parameterAsString( parameters, QStringLiteral(
"FOLDER" ), context );
89 if ( !QDir().mkpath( folder ) )
92 const QDir dir( folder );
93 const QString filenameExpressionString = parameterAsString( parameters, QStringLiteral(
"FILENAME" ), context );
94 QgsExpressionContext expressionContext = createExpressionContext( parameters, context, input.get() );
97 fields.insert( fieldName );
100 QgsExpression filenameExpression( filenameExpressionString );
101 filenameExpression.prepare( &expressionContext );
102 fields.unite( filenameExpression.referencedColumns() );
104 if ( !filenameExpression.needsGeometry() )
108 const double step = input->featureCount() > 0 ? 100.0 / input->featureCount() : 1;
121 const QByteArray ba = feat.
attribute( fieldIndex ).toByteArray();
126 const QString name = filenameExpression.evaluate( &expressionContext ).toString();
127 if ( filenameExpression.hasEvalError() )
129 feedback->
reportError( QObject::tr(
"Error evaluating filename: %1" ).arg( filenameExpression.evalErrorString() ) );
133 const QString path = dir.filePath( name );
135 if ( !file.open( QIODevice::WriteOnly | QFile::Truncate ) )
137 feedback->
reportError( QObject::tr(
"Could not open %1 for writing" ).arg( path ) );
143 feedback->
pushInfo( QObject::tr(
"Extracted %1" ).arg( path ) );
148 outputs.insert( QStringLiteral(
"FOLDER" ), folder );
@ 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.
@ SkipGeometryValidityChecks
Invalid geometry checks should always be skipped. This flag can be useful for algorithms which always...
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the context.
Handles parsing and evaluation of expressions (formerly called "search strings").
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.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
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.
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 pushInfo(const QString &info)
Pushes a general informational message from the algorithm.
virtual void reportError(const QString &error, bool fatalError=false)
Reports that the algorithm encountered an error while executing.
An expression parameter 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 folder destination parameter, for specifying the destination path for a folder created by the algor...