Jak uzyskać nazwy pól w pyqgis 2.0

13

Próbuję zmienić wtyczkę z QGIS 1.8 na 2.0. W wersji 1.8 tworzę tabelę nazw pól takich jak to:

layer = vlayer
provider = layer.dataProvider()
feat = QGSFeatrue()
allAttrs = provider.attributeIndexes()
provider.select(allAttrs)
fieldNames = []

while provider.nextFeature(feat)
    fields = layer.pendingFields()
    for (k, field) in fields.iteritems():
         fieldNames.append(field.name())

Próbowałem tego dla wersji 2.0 z

layer = vlayer
fieldNames = []

for feature in layer.getFeatures():
    fields = layer.pendingFields()
    for (k, field) in fields.iteritems():
         fieldNames.append(field.name())

Ale pendingFields () nie działa dla mnie. Czy istnieje teraz nowa metoda uzyskiwania nazw pól?

Jaskółka oknówka
źródło

Odpowiedzi:

24

To jest prostsze niż w wersji 1.8:

layer = qgis.utils.iface.activeLayer()  
fields = layer.pendingFields()   
field_names = [field.name() for field in fields]

lub w jednej linii

field_names = [field.name() for field in layer.pendingFields() ]

po

for elem in layer.getFeatures():  
   print dict(zip(field_names, elem.attributes()))
{u'adip': 17, u'dipdir': 130, u'tdip': 29}
{u'adip': 55, u'dipdir': 325, u'tdip': 75}
.....

Zasadniczo do eksploracji nowej funkcji używam dir () lub modułu see , aby sprawdzić, co jest w środku:

dir(fields)
['FieldOrigin', 'OriginEdit', 'OriginJoin', 'OriginProvider', 'OriginUnknown', '__class__', '__delattr__', '__delitem__', '__dict__', '__doc__', '__format__', '__getattribute__', '__getitem__', '__hash__', '__init__', '__len__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'append', 'at', 'clear', 'count', 'extend', 'field', 'fieldOrigin', 'fieldOriginIndex', 'indexFromName', 'isEmpty', 'remove', 'size', 'toList']

lub

see(fields)
[]                 hash()             help()             len()
repr()             str()              .FieldOrigin()     .OriginEdit
.OriginJoin        .OriginProvider    .OriginUnknown     .append()
.at()              .clear()           .count()           .extend()
.field()           .fieldOrigin()     .fieldOriginIndex()
.indexFromName()   .isEmpty()         .remove()          .size()
.toList()

I widać, że istnieje funkcja field ()

print fields.field(0)
qgis.core.QgsField object at 0x163E39C0

a pole ma nazwę, typ, precyzję, ...:

see(fields.field(0))
<                 <=                ==                !=                >
>=                hash()            help()            repr()
str()             .comment()        .displayString()  .length()
.name()           .precision()      .setComment()     .setLength()
.setName()        .setPrecision()   .setType()        .setTypeName()
.type()           .typeName()

więc:

fields.field(0).name()
u'adip'
fields.field(0).type()
2
fields.field(0).typeName()
u'Integer'
fields.field(0).precision()
0
....

z .dataProvider ()

Jest to .field ()

....
prov = layer.dataProvider()
prov.fields().field(0).name()
u'adip'
prov.fields().field(0).typeName()
u'Integer'

i

field_names = [field.name() for field in prov.fields()]
gen
źródło
ok to działa, ale tylko w edytorze Python qgis. Kiedy korzystam z tej funkcji we wtyczce, nic się nie dzieje. Funkcja działa do pola w polach, ale tam się zatrzymuje. Próbowałem później wyświetlić okno komunikatu, ale nie dociera ono do linii kodowej. Może zapomniałem coś zaimportować? Mam zaimportowane pliki qgis.core, qgis.gui i qgis.utils.
Martin
musisz użyć .dataprovider (), patrz dodatek w mojej odpowiedzi
gen
Dziękuję Ci. To działa. Problem polegał na tym, że próbuję uzyskać identyfikator warstwy z warstwy aktywnej, getLayerID()ale to już nie działa.
Martin
2

Działa na przykład w ten sposób (od ostatniej wersji QGIS dev 1.9):

layer = vlayer # QGsVectorlayerObject
prov = vlayer.dataProvider()
fieldNames = []
fields = prov.fields()
for field in fields:
    fieldNames.append( field.name() )
Kulik
źródło
1
Dla mnie to nie działa. Kiedy próbuję iterować przez pola, nic się nie dzieje. Czy dataProvider w wersji 2.0 jest nadal użyteczny?
Martin
1
jup to jest. A dla mojej wtyczki powyższy kod działa bez problemów. spróbuj wydrukować typ i treść obiektów podczas wykonywania kodu. Pomaga w debugowaniu
Curlew,
współpracował z QgsMapLayerRegistry.instance (). mapLayers (). values ​​():
Muhammad Faizan Khan