[英]PyQGIS - Adding layer from PostGis database and work with it in QGIS interface
我尝试从我的数据库 postgis 添加到我的 QGIS 接口一个表,我正在使用具有良好参数的脚本。 但我的问题是当我运行我的 function 时我的 QGIS 错误并关闭。
from qgis.core import *
from qgis.core import QgsProject
from PyQt5.QtCore import QFileInfo
from qgis.core import QgsVectorLayer, QgsDataSourceUri
from qgis.utils import *
def run_script(iface):
uri = QgsDataSourceUri()
uri.setConnection("localhost", "5432", "Base_test", "user", "passeword")
uri.setDataSource("public", "BPE", "geom")
layer = QgsVectorLayer(uri.uri(), "bpe", "user")
if not layer.isValide():
print("Layer %s did not load" %layer.name())
QgsProject.instance().addMapLayer(layer)
它说我该层没有加载。 之后需要重新启动 QGIS。
有人能帮助我吗。
我正在使用 QGIS 3.10
试试这个代码:
from qgis.core import *
from qgis.core import QgsProject
from PyQt5.QtCore import QFileInfo
from qgis.core import QgsVectorLayer,
QgsDataSourceUri
from qgis.utils import *
def run_script(iface):
uri = QgsDataSourceUri()
uri.setConnection("localhost", "5432", "Base_test",
"user", "passeword")
uri.setDataSource("public", "BPE", "geom")
layer = QgsVectorLayer(uri.uri(), "bpe", "postgres")
if not layer.isValid():
print("Layer %s did not load" %layer.name())
QgsProject.instance().addMapLayer(layer)
run_script()
if not layer.isValide()
--> if notlayer.isValid()
layer = QgsVectorLayer(uri.uri(), "bpe", "user")
--> layer=QgsVectorLayer(uri.uri(), "bpe", "postgres")
run_script()
检查文档: https://qgis.org/pyqgis/3.0/core/Vector/QgsVectorLayer.html
干杯
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.