我在 fiona 模块方面的经验很少(从今天开始!)我有一个名为 building.gpkg 的地理包,其中有一个名为“id”的字段,在生产时为 NULL。
我正在尝试使用 fiona 模块编写一个 python 脚本,以根据存储在 SQL Server 中的另一个表中可用的 ID 填充其 ID。
虽然我已通过 fiona 成功导入并读取 bldg.gpkg,但我正在努力将数据写入 id 列:
这是示例代码:
import fiona
bldg_gpkg = 'building.gpkg'
with fiona.open(bldg_gpkg, 'w') as c:
for i in range(max_id, len(list(c))+max_id):
c.next()['properties']['id'] = i
这是我得到的错误:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\Program Files\Python3\lib\site-packages\fiona\env.py", line 407, in wrapper
return f(*args, **kwargs)
File "C:\Program Files\Python3\lib\site-packages\fiona\__init__.py", line 265, in open
c = Collection(path, mode, crs=crs, driver=driver, schema=this_schema,
File "C:\Program Files\Python3\lib\site-packages\fiona\collection.py", line 126, in __init__
raise DriverError("no driver")
fiona.errors.DriverError: no driver
我查看了 fiona 模块中的 collection.py 和 drvsupport.py 并安装并支持了 GPKG 驱动程序是否有我遗漏的东西?还是写作方法不对?
我在 Windows 10 上运行 Python 3.8.1。
谢谢