當前位置: 首頁>>代碼示例>>Python>>正文


Python VectorWriter.addFeature方法代碼示例

本文整理匯總了Python中processing.tools.vector.VectorWriter.addFeature方法的典型用法代碼示例。如果您正苦於以下問題:Python VectorWriter.addFeature方法的具體用法?Python VectorWriter.addFeature怎麽用?Python VectorWriter.addFeature使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在processing.tools.vector.VectorWriter的用法示例。


在下文中一共展示了VectorWriter.addFeature方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: VectorWriter

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
##[Example scripts]=group
##input=vector
##output=output vector

from qgis.core import *
from processing.tools.vector import VectorWriter

vectorLayer = processing.getObject(input)

provider = vectorLayer.dataProvider()

writer = VectorWriter(output, None, provider.fields(),
                      provider.geometryType(), vectorLayer.crs())

features = processing.features(vectorLayer)

writer.addFeature(next(features.iter))

del writer
開發者ID:GeoCat,項目名稱:qgis-geoserver-plugin,代碼行數:21,代碼來源:vector_hook.py

示例2: QgsPoint

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
                maxarea = area
        inGeom = tmpGeom
    atMap = inFeat.attributes()
    if QGis.QGIS_VERSION > '2.4':
        outGeom = inGeom.pointOnSurface()
    else:
        outGeom = inGeom.centroid()
    if not inGeom.contains(outGeom):
        # weight point outside the polygon
        # find intersection of horizontal line through the weight pont
        rect = inGeom.boundingBox()
        horiz = QgsGeometry.fromPolyline([QgsPoint(rect.xMinimum(), outGeom.asPoint()[1]), QgsPoint(rect.xMaximum(), outGeom.asPoint()[1])])
        line = horiz.intersection(inGeom)
        if line.isMultipart():
            # find longest intersection
            mline = line.asMultiPolyline()
            l = 0
            for i in range(len(mline)):
                d = sqrt((mline[i][0][0] - mline[i][1][0])**2 + (mline[i][0][1] - mline[i][1][1])**2)
                if d > l:
                    l = d
                    xMid = (mline[i][0][0] + mline[i][1][0]) / 2.0
                    yMid = (mline[i][0][1] + mline[i][1][1]) / 2.0
        else:
            xMid = (line.vertexAt(0).x() + line.vertexAt(1).x()) / 2.0
            yMid = (line.vertexAt(0).y() + line.vertexAt(1).y()) / 2.0
        outGeom = QgsGeometry.fromPoint(QgsPoint(xMid, yMid))
    outFeat.setAttributes(atMap)
    outFeat.setGeometry(outGeom)
    outputLayer.addFeature(outFeat)
開發者ID:spatialthoughts,項目名稱:QGIS-Processing,代碼行數:32,代碼來源:realcentroid_algorithm.py

示例3: VectorWriter

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
l = 0

writer = VectorWriter(Results, None, polyPrder.fields(),
					  QGis.WKBMultiPolygon, polyPrder.crs())
					  

resgeom = QgsGeometry()
resfeat = QgsFeature()

for feat in processing.features(polyLayer):
	progress.setPercentage(int(100*l/n))
	l+=1
	
	g = loads(feat.geometry().asWkb())
	
	if g.geom_type == 'MultiPolygon':		
		resg = [Polygon(p.exterior,
				[r for r in p.interiors if Polygon(r).area > Max_area]) for p in g]
					
	else:
		resg = [Polygon(g.exterior,
				[r for r in g.interiors if Polygon(r).area > Max_area])]

	resgeom = QgsGeometry().fromWkt(dumps(MultiPolygon(resg)))
	
	resfeat.setAttributes(feat.attributes())
	resfeat.setGeometry(resgeom)	
	writer.addFeature(resfeat)		

del writer
開發者ID:SIGISLV,項目名稱:QGIS-Processing,代碼行數:32,代碼來源:Fill_holes.py

示例4: VectorWriter

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
##Centroids=name
##Geometry=group
##INPUT_LAYER=vector
##OUTPUT_LAYER=output vector

from qgis.core import QgsWkbTypes, QgsGeometry

from processing.tools.vector import VectorWriter
from processing.tools import dataobjects

layer = dataobjects.getLayerFromString(INPUT_LAYER)
fields = layer.fields()

writer = VectorWriter(OUTPUT_LAYER, 'utf-8', fields, QgsWkbTypes.Point, layer.crs())

features = processing.features(layer)
count = len(features)
if count == 0:
    raise GeoAlgorithmExecutionException('Input layer contains no features.')

total = 100.0 / len(features)

for count, f in enumerate(features):
    outputFeature = f
    if f.hasGeometry():
        outputGeometry = f.geometry().centroid()
        outputFeature.setGeometry(outputGeometry)

    writer.addFeature(outputFeature)
    feedback.setProgress(int(count * total))
開發者ID:cayetanobv,項目名稱:QGIS,代碼行數:32,代碼來源:centroids.py

示例5: VectorWriter

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
for selected in selected_layers:
    layer = processing.getObject(selected)
    output_path = os.path.join(Output_Folder, layer.name() + '.shp')
    projected += 1
    progress.setPercentage(int(100 * projected / selected_count))
    
    # check exist Ovewrite
    if os.path.isfile(output_path) and Ovewrite == False:
        print "Already exists: " + output_path
        continue
    
    trans.setSourceCrs(layer.crs())
    
    # reprojecting layers
    writer = VectorWriter(output_path, None, layer.dataProvider().fields(), 
                          layer.dataProvider().geometryType(), dest_crs)
    features = processing.features(layer)
    for feature in features:
        # transform geometry http://www.qgis.org/api/classQgsGeometry.html
        geometry = feature.geometry()
        geometry.transform(trans)
        
        # create & insert feature
        new_feature = QgsFeature()
        new_feature.setGeometry(geometry)
        new_feature.setAttributes(feature.attributes())
        writer.addFeature(new_feature)
    del writer

output = selected_count
開發者ID:nakijun,項目名稱:qgis-scripts,代碼行數:32,代碼來源:Reproject+Vector+Layers.py

示例6:

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
  else:
    polygon = geom.asPolygon()
    polygon_area = area.measurePolygon(polygon[0])

  # calculated area is in sq. metres
  if units_selection == 'sq_km':
    final_area = polygon_area / 1e6
  elif units_selection == 'sq_ft':
    final_area = area.convertMeasurement(
        polygon_area, QGis.Meters, QGis.Feet, True)[0]
  elif units_selection == 'sq_miles':
    final_area = area.convertMeasurement(
        polygon_area, QGis.Meters, QGis.Feet, True)[0] / (5280.0 * 5280.0)
  elif units_selection == 'sq_nm':
    final_area = area.convertMeasurement(
        polygon_area, QGis.Meters, QGis.NauticalMiles, True)[0]
  elif units_selection == 'sq_degrees':
    final_area = area.convertMeasurement(
        polygon_area, QGis.Meters, QGis.Degrees, True)[0]
  else:
    final_area = polygon_area

  attrs = feat.attributes()
  attrs.append(final_area)
  out_f.setGeometry(geom)
  out_f.setAttributes(attrs)
  writer.addFeature(out_f)

progress.setPercentage(100)
del writer
開發者ID:SIGISLV,項目名稱:QGIS-Processing,代碼行數:32,代碼來源:ellipsoidal_area.py

示例7: createSample

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]

#.........這裏部分代碼省略.........
        #Open layer sample 
        layer_sample = processing.getObject(Vector_samples)
        #Get index fields
        idx_field_class = layer_sample.fieldNameIndex(Classes_field)
        #iniciar variaveis auxiliares
        self.classes=[]
        self.training=[]
        #Get names fields sample
        layer_features = layer_sample.getFeatures()
        fields = layer_sample.pendingFields()
        #Get names fields sample
        fields_names = [str(i.name()) for i in fields]
        #Remover field class
        fields_names.remove(Classes_field)
        #Loop about features sample
        for feat in layer_features:
            #Get values attibutes
            attributes = feat.attributes()
            #Remove values classes e add in variable
            v_class = attributes.pop(idx_field_class)
            #Append value class
            self.classes.append(v_class)
            #Create dict from attr
            atr = dict(zip(fields_names, attributes))
            #Append in training
            self.training.append(atr)
            
    def createDatas(self):
        '''
        Input datas vector
        Create array from vector 
        Output datas (list(dict))
        '''
        
        #Open layer datas
        self.layer_datas = processing.getObject(Vector_datas)

        #iniciar variaveis auxiliares
        self.datas=[]
        #Get names fields sample
        features_datas = self.layer_datas.getFeatures()
        #Get fields vector datas
        fields = self.layer_datas.pendingFields()
        #Get names fields sample
        fields_names = [str(i.name()) for i in fields]
        #Loop features datas vector
        for feat in features_datas:
            #create datas from dict
            atr = dict(zip(fields_names, feat.attributes()))
            self.datas.append(atr)
  
    def classifierTree(self,Max_depth):
        '''
        Create model tree 
        Input training (list(dicy)), class (list) and datas (list(dict))
        Output list with classification of Datas
        '''
    
        #Create fit transform
        trans_train = vec.fit_transform(self.training).toarray()
        del(self.training)
        trans_datas = vec.fit_transform(self.datas).toarray()
        
        #Choose type classification
        clf = tree.DecisionTreeClassifier( max_depth = Max_depth)
        #Crate model classification tree
        modelTree = clf.fit(trans_train, self.classes)
        print 'max_n_classes, ', modelTree.tree_.max_n_classes
        print 'node_count: ', modelTree.tree_.node_count
        print 'min_density: ', modelTree.tree_.min_density
        print 'n_outputs: ', modelTree.tree_.n_outputs
        print 'n_features: ', modelTree.tree_.n_features
        print 'n__classes: ', modelTree.tree_.n_classes
        print 'n_samples: ', modelTree.tree_.n_samples
    
        del(trans_train)
        del(self.classes)
        #Apply model classification in Datas
        self.classificationDatas = modelTree.predict(trans_datas)
        
        with open("/home/ruiz/tree.dot", 'w') as f:
            f = tree.export_graphviz(modelTree, out_file=f)
    def writeClassification(self):
        #Create vector to write
        provider = self.layer_datas.dataProvider()
        #fields
        fields = provider.fields()
        fields=[i for i in fields]
        fields.append(QgsField("class", QVariant.Int))
        #Create shape writer
        self.writer = VectorWriter(Output_classification, None, fields, provider.geometryType(), self.layer_datas.crs())
        for i, feat in enumerate(self.layer_datas.getFeatures()):
            #Add features write
            fet = QgsFeature()
            fet.setGeometry(feat.geometry())
            attrs=feat.attributes()
            attrs.append(int(self.classificationDatas[i]))
            fet.setAttributes(attrs)
            self.writer.addFeature(fet)     
        del(self.writer)
開發者ID:RuizGeo,項目名稱:classification_decision_tree,代碼行數:104,代碼來源:classification_by_decision_tree.py

示例8: freq_min_max

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
    if count == 0:
        majority = 0
        minority = 0
        majority_p = 0
        minority_p = 0
    else:
        minority, majority = freq_min_max(freq)
        minority = int(minority)
        majority = int(majority)
        minority_p = float(freq[minority]) / count
        majority_p = float(freq[majority]) / count

    # write to layer
    outFeat.setGeometry(feat.geometry())
    attrs = feat.attributes() + [majority, majority_p, minority, minority_p]
    outFeat.setAttributes(attrs)
    layer_writer.addFeature(outFeat)

    # write to table
    row = [feat[id_field], majority]
    for v in values:
        if v in freq:
            row.append(float(freq[v]) / count)
        else:
            row.append(0)
    table_writer.addRecord(row)

progress.setPercentage(100)
del table_writer
del layer_writer
開發者ID:SIGISLV,項目名稱:QGIS-Processing,代碼行數:32,代碼來源:FrequencyStats.py

示例9: range

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
					  QGis.WKBMultiPolygon, polyPrder.crs())


for feat in processing.features(polyLayer):
	progress.setPercentage(int(100*l/n))
	l+=1
	
	geom = feat.geometry()
	
	if geom.isMultipart():
	
		featres = feat
	
		geoms = geom.asGeometryCollection()
		geomlength = [(i, geoms[i].area()) for i in range(len(geoms))]
		
		geomlength.sort(key=itemgetter(1))
		
		if To_keep == 1:
			featres.setGeometry(geoms[geomlength[-1][0]])
		else: 
			geomres = [geoms[i].asPolygon() for i,a in geomlength[-1 * To_keep]]
			featres.setGeometry(QgsGeometry.fromMultiPolygon(geomres))
		
		writer.addFeature(featres)
		
	else:
		writer.addFeature(feat)

del writer
開發者ID:SIGISLV,項目名稱:QGIS-Processing,代碼行數:32,代碼來源:Keep_n_biggest_parts.py

示例10: VectorWriter

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
##[Example scripts]=group
##input=vector
##output=output vector

from qgis.core import *
from processing.tools.vector import VectorWriter

vectorLayer = processing.getObject(input)

provider = vectorLayer.dataProvider()

writer = VectorWriter(output, None, provider.fields(),
                      provider.geometryType(), vectorLayer.crs())

features = processing.features(vectorLayer)

writer.addFeature(features.iter.next())

del writer
開發者ID:Ezio47,項目名稱:qgis-geoserver-plugin,代碼行數:21,代碼來源:vector_hook.py

示例11: SequenceGenerator

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
            feat.setGeometry(QgsGeometry.fromPolyline([p1,p2]))
            feat.setAttributes([key[0],key[1],value])
            lines.append(feat)
        return lines

centroid_layer = processing.getObject(input_cell_centers)
trajectory_layer = processing.getObject(input_trajectories)
sg = SequenceGenerator(centroid_layer,trajectory_layer, weight_field if use_weight_field else None)

fields = [QgsField('FROM', QVariant.Int),
              QgsField('TO', QVariant.Int),
              QgsField('COUNT', QVariant.Int)]
geom_type = 2
writer = VectorWriter(flow_lines, None, fields, geom_type, centroid_layer.crs() )
for f in sg.create_flow_lines():
    writer.addFeature(f)
del writer 

fields = centroid_layer.fields()
fields.append( QgsField('COUNT',QVariant.Int))
fields.append( QgsField('COUNT_Q1',QVariant.Int))
fields.append( QgsField('COUNT_Q2',QVariant.Int))
fields.append( QgsField('COUNT_Q3',QVariant.Int))
fields.append( QgsField('COUNT_Q4',QVariant.Int))
writer = VectorWriter(cell_counts, None, fields, 1, centroid_layer.crs() )
for key, value in sg.id_to_centroid.iteritems():
    (in_feature, n) = value
    out_feature = QgsFeature()
    out_feature.setGeometry(in_feature.geometry())
    attributes = in_feature.attributes()
    attributes.append(n[0])
開發者ID:anitagraser,項目名稱:QGIS-Processing-tools,代碼行數:33,代碼來源:compute_flows_between_cells_from_trajectories.py

示例12: or

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
            # l'intersection se fait avec le polygone bufferise
            if not no_blank or (no_blank and rectangle.intersects(buffer_geom)):
                id_tile += 1
                id_poly_tile += 1
                new_feat = QgsFeature()
                new_feat.setGeometry(rectangle)
                # attributs standards
                attribute_values = feature.attributes()[:]                                              
                # attributs supplementaires
                attribute_values.extend([id_poly, id_tile, id_poly_tile, row_poly_tile, col_poly_tile]) 
                # attribut supplementaire pour tri
                if ord_field:
                    attribute_values.append('{}#{:04d}'.format(feature[ord_field], id_poly_tile))     
                # attributs supplementaires coord dalle
                if tile_bound:
                    attribute_values.extend([min_x_tile, max_x_tile, min_y_tile, max_y_tile])           
                # attributs supplementaires coord enveloppe
                if poly_bound:
                    attribute_values.extend([min_x_poly, max_x_poly, min_y_poly, max_y_poly])           

                # ajoute les geometries et valeurs des enregistrements
                new_feat.setAttributes(attribute_values)
                vw_grid.addFeature(new_feat)
del vw_grid

# pour memoire :
#QMessageBox.information(None, 'DEBUGn: ' , 'texte') # pas recommande !
#progress.setInfo('texte')
#progress.setText('texte')
#raise GeoAlgorithmExecutionException('texte')
開發者ID:sigvar,項目名稱:grille,代碼行數:32,代碼來源:couche_de_couverture.py

示例13: VectorWriter

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
    cell_feature.setAttributes(ret)
    centroid_features[idx_side] = cell_feature

#. write features
cell_writer = VectorWriter(Output_layer, None, cell_fields, QGis.WKBPolygon, input_layer.crs())
for idx_side in xrange(DEFAULT_SEGS):
    cell_feature = centroid_features[idx_side]
    value = cell_feature.attributes()[3]
    linear_trans_value = (value - minVal) / (maxVal - minVal);
    adjusted_radius = linear_trans_value * radius
    if adjusted_radius > 0:
        from_deg = (idx_side * step_angle) - half_step
        to_deg = ((idx_side + 1) * step_angle) - half_step
        cell = create_cell(center_point, from_deg, to_deg, adjusted_radius)
        cell_feature.setGeometry(cell)
        cell_writer.addFeature(cell_feature)

del cell_writer

#. write anchor      
cell_fields = QgsFields()
cell_fields.append(QgsField("distance", QVariant.Double))
cell_fields.append(QgsField("direction", QVariant.String))
anchor_writer = VectorWriter(Output_Anchor, None, cell_fields, QGis.WKBLineString, input_layer.crs())

radius_step = radius / 5
center =  QgsGeometry.fromPoint(center_point)
for idx_side in xrange(5):
    buffer_radius = radius_step * (idx_side + 1)
    anchor_feature = QgsFeature(cell_fields)
    anchor_feature.setGeometry(center.buffer(buffer_radius, 32))
開發者ID:dassouki,項目名稱:qgis-scripts,代碼行數:33,代碼來源:Create+WindRose+Maps.py

示例14: QgsFields

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
 *                                                                         *
 ***************************************************************************/
"""
##[My Scripts]=group
##Vector Field Case Converter=name
##Vector_Layer=vector
##Upper_Case=boolean
##Output=output vector

from qgis.core import *
from processing.tools.vector import VectorWriter

vectorLayer = processing.getObject(Vector_Layer)
provider = vectorLayer.dataProvider()

# rebuild fields
new_fields = QgsFields()
for field in provider.fields():
    field_name = field.name().upper() if Upper_Case else field.name().lower()
    field.setName(field_name)
    new_fields.append(field)
    
# write features
writer = VectorWriter(Output, None, new_fields, provider.geometryType(), vectorLayer.crs())

features = processing.features(vectorLayer)
for feature in features:
    writer.addFeature(feature)

del writer
開發者ID:dassouki,項目名稱:qgis-scripts,代碼行數:32,代碼來源:Vector+Fields+Case+Converter.py

示例15: Grid

# 需要導入模塊: from processing.tools.vector import VectorWriter [as 別名]
# 或者: from processing.tools.vector.VectorWriter import addFeature [as 別名]
grid = Grid(bbox,max_radius)
print("Inserting {} points ...".format(len(points)))
grid.insert_points(points)
print("Redistributing {} points ...".format(len(points)))
grid.redistribute_points(points)

fields = [QgsField('GROUP', QVariant.Int)]
geom_type = 1 # point 
writer_pts = VectorWriter(grouped_points, None, fields, geom_type, l.crs() )
writer_centroids = VectorWriter(group_centroids, None, fields, geom_type, l.crs() )

print("Writing {} groups ...".format(len(grid.resulting_groups)))

for id,g in enumerate(grid.resulting_groups):
    fet2 = QgsFeature()
    fet2.setGeometry(QgsGeometry.fromPoint(g.centroid))
    fet2.setAttributes([id])
    writer_centroids.addFeature(fet2)
    for pt in g.points:
        fet = QgsFeature()
        fet.setGeometry(QgsGeometry.fromPoint(pt))
        fet.setAttributes([id])
        writer_pts.addFeature(fet)
    
    
    
del writer_pts
del writer_centroids


開發者ID:anitagraser,項目名稱:QGIS-Processing-tools,代碼行數:30,代碼來源:group_points_in_space.py


注:本文中的processing.tools.vector.VectorWriter.addFeature方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。