Tengo una secuencia de comandos de python (para ArcGIS 10), que crea una nueva geodatabase de archivos, se crea una nueva clase de entidad en la geodatabase y, a continuación, lee los datos de un SDE clase de entidad para rellenar la nueva clase de entidad. El script funciona bien, excepto que un bloqueo se coloca en la geodatabase de archivos que persiste después de ejecutar el script. La base de datos no puede ser eliminado con ArcCatalog. Una vez que la nueva clase de entidad que se elimina, entonces la geodatabase de archivos pueden ser borrados.
En el script que elimine las referencias a todos los cursores y las filas y aún así el bloqueo continúa. A continuación está el código correspondiente. ¿Qué estoy haciendo mal?
import arcpy
OutputFolder = arcpy.GetParameterAsText(0)
FGDName = arcpy.GetParameterAsText(1)
StringInputWorkspace = arcpy.GetParameterAsText(2)
SourceFCAddressPoints = StringInputWorkspace + '\\sde.ERLANDSEN.AddressPoints'
## Create File GDB...
Output_gdb = OutputFolder + '\\' + FGDName + '.gdb'
arcpy.CreateFileGDB_management(OutputFolder, FGDName)
## Set current workspace to to file geodatabase
arcpy.env.workspace = Output_gdb
NewAddressPoints = Output_gdb + '\\AddressPoints'
## Create Feature Class...
arcpy.CreateFeatureclass_management(Output_gdb, "AddressPoints", "POINT", "", "DISABLED", "DISABLED", "PROJCS['NAD_1983_StatePlane_Washington_North_FIPS_4601_Feet',GEOGCS['GCS_North_American_1983',DATUM['D_North_American_1983',SPHEROID['GRS_1980',6378137.0,298.257222101]],PRIMEM['Greenwich',0.0],UNIT['Degree',0.0174532925199433]],PROJECTION['Lambert_Conformal_Conic'],PARAMETER['False_Easting',1640416.666666667],PARAMETER['False_Northing',0.0],PARAMETER['Central_Meridian',-120.8333333333333],PARAMETER['Standard_Parallel_1',47.5],PARAMETER['Standard_Parallel_2',48.73333333333333],PARAMETER['Latitude_Of_Origin',47.0],UNIT['Foot_US',0.3048006096012192]];IsHighPrecision", "", "0", "0", "0")
## Add fields
arcpy.AddField_management(NewAddressPoints, "AddressPointID", "LONG", "", "", "", "", "NULLABLE", "NON_REQUIRED", "")
curSourceAddresses = arcpy.SearchCursor(SourceFCAddressPoints)
curNewAddressPoints = arcpy.InsertCursor(NewAddressPoints)
for rowSourceAddress in curSourceAddresses:
rowNewAddress = curNewAddressPoints.newRow()
rowNewAddress.SHAPE = rowSourceAddress.SHAPE
rowNewAddress.AddressPointID = rowSourceAddress.OBJECTID
del rowNewAddress
del rowSourceAddress
del curSourceAddresses
del curNewAddressPoints