zoukankan      html  css  js  c++  java
  • 学习《Building Applications with FME Objects》 之四 从数据集读取要素

    FMEOReader可以访问任何支持格式的数据。

    image

    FMEOReader返回两类要素:schema(模式)要素和数据要素,模式要素用于描述数据集模型。每种支持的格式都有一个模式,一个模式要素是一类要素的数据模型,模式要素描述属性、坐标系和几何要素类型。

    本章可以学习到:

    • 创建reader
    • 打开reader
    • 获取reader设置
    • 获得活动reader信息
    • 返回模式要素
    • 返回数据要素
    • 关闭reader

    创建Reader

    必须通过FMEOSession对象的createReader方法创建,如下

    Dim fmeDirectives As FMEOStringArray
    Set fmeDirectives = m_fmeSession.createStringArray
    fmeDirectives.append ("OUTPUT_STATS")
    fmeDirectives.append ("NO")
    Set m_fmeReader = m_fmeSession.createReader("SHAPE", _
                                     False, fmeDirectives)

    格式类型表示是唯一的,用于控制reader的创建,些在createReader方法的第一个参数,SHAPE用于创建ESRI Shapefile reader,下面是它的描述:

    image

    image

    注意:FME对象的读写取决于上表中的Reader/Writer行。

    createReader第二个参数为布尔值,用于决定是否创建要素磁盘缓存,如果你的应用程序需要多次访问要素集,它将缓存以提高性能,多次访问数据集缓存则可以减少I/O请求,当缓存时,FME对象创建一个基于基于磁盘的空间索引以方便快速随机访问要素并允许高级空间和属性查询,

    createReader第三个参数为字符串数组,包含下表中的参数,以名和值成对出现:

    image

    打开Reader

    一旦创建了reader,就可以打开指定的数据集,下面代码SHAPE reader读取c:\shape:

    Dim fmekeywords As FMEOStringArray
    Set fmeKeywords = m_fmeSession.createStringArray
    fmeKeywords.append(“MEASURES_AS_Z”)
    fmeKeywords.append(“YES”)
    fmeKeywords.append(“IDs”)
    fmeKeywords.append(“roads.shp”)
    fmeKeywords.append(“IDs”)
    fmeKeywords.append(“rivers.shp”)
    Call m_fmeReader.open(“c:\shape”, fmeKeywords)

    第一个参数,对于ESRI Shapefile reader来说,需要一个数据集目录,其他的reader可能会需要一个数据集文件、数据库或URL,详细信息查看Quick Facts table。

    第二个参数是一个字符串数组,名字和数值成对出现,控制reader的操作。

    用户设置Reader参数

    通过FMEODialog对象,简单的创建和打开一个新的reader,FMEODialog的sourcePrompt方法显示一个对话框并且获得用户的数据。

    例如:

    image

    注意:FMEODialog对象仅仅用于WINDOWS平台,其他操作系统中不可用。

     

    SourcePrompt方法返回用户指定的参数,将返回的参数再传递给FMEOSession的createReader和FMEOReader的open方法:

    Public Sub SourcePrompt(sSourceDir As String)
        Dim fmeDialog As FMEODialog
        Dim fmeDirectives As FMEOStringArray
        Dim fmeKeywords As FMEOStringArray
        Dim sDataset As String
        Dim sFormat As String
        Dim bCompleted As Boolean
        Set fmeDialog = m_fmeSession.createDialog
        Set fmeDirectives = m_fmeSession.createStringArray
        Call fmeDirectives.append("LIMIT_FORMATS")
        Call fmeDirectives.append("MIF")
        bCompleted = fmeDialog.SourcePrompt("MIF", sSourceDir, _
                                 sFormat, sDataset, fmeDirectives)
        If bCompleted = True Then
            Set m_fmeReader = m_fmeSession.createReader(sFormat, _

                              True, fmeDirectives)
            Set fmeKeywords = m_fmeSession.createStringArray
            Call m_fmeReader.open(sDataset, fmeKeywords)
            m_bReaderOpened = True
        End If
    End Sub

    下面是SourcePrompt方法的参数:

    image

    从活动的Reader中获取信息

    用输入数据源会话框,最红用户可以从格式列表中选择格式,如果你的应用程序需要访问可用的格式列表,可以使用FMEODialog对象的getAvailableFormats方法。并且可以通过FMEODialog对象的getAvailableFormats方法获得可用格式的详细信息.

    下面的代码显示一个对话框来显示指定Reader的全部信息:

    Public Sub GetReaderInfo(ByVal sFormatName As String)
        Dim lPos As Long
        Dim sMsg As String
        Dim sDirection As String
        Dim bSpatialIndex As Boolean
        Dim fmeDialog As FMEODialog
        Dim fmeFormats As FMEOStringArray
        Dim fmeFormatInfo As FMEOStringArray
        Set fmeDialog = m_fmeSession.createDialog
        Set fmeFormats = m_fmeSession.createStringArray
        Set fmeFormatInfo = m_fmeSession.createStringArray
        Call fmeDialog.getAvailableFormats(fmeFormats)
        lPos = GetIndex(fmeFormats, sFormatName)
        If lPos = -1 Then
            sMsg = "Format not available: "

            sMsg = sMsg & sFormatName & vbCrLf
            MsgBox sMsg, vbOKOnly, "GetReaderInfo"
            Exit Sub
        End If
        Call fmeDialog.getFormatInfoEx(sFormatName, fmeFormatInfo)
        sMsg = "Format: " & sFormatName
        lPos = GetIndex(fmeFormatInfo, "FORMAT_LONG_NAME")
        sMsg = sMsg & vbCrLf & "Long Name: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "DATASET_TYPE")
        sMsg = sMsg & vbCrLf & "Dataset Type: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "INPUT_OUTPUT")
        sMsg = sMsg & vbCrLf & "Direction: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "FILE_EXTENSIONS")
        sMsg = sMsg & vbCrLf & "File Filter: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "COORD_SYSTEM_AWARE")
        sMsg = sMsg & vbCrLf & "Coordinate System Aware: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "SOURCE_SETTINGS")
        sMsg = sMsg & vbCrLf & "Has Source Settings: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "DESTINATION_SETTINGS")
        sMsg = sMsg & vbCrLf & "Has Destination Settings: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        lPos = GetIndex(fmeFormatInfo, "AUTOMATED_TRANSLATION")
        sMsg = sMsg & vbCrLf & "Supports Automated Translation: "
        sMsg = sMsg & fmeFormatInfo.element(lPos + 1)
        MsgBox sMsg, vbOKOnly, "GetReaderInfo"
    End Sub

     

    FMEODialog对象的getFormatInfoEx方法返回的信息为名字数值对,下列表格为名字列表:

    image

    关于FMEOReader对象的额外信息,可以用它的getProperties方法获得,例如:

    Set fmeProperties = m_fmeSession.createStringArray
    Call m_fmeReader.getProperties("fme_prop_spatial_index", _
    fmeProperties)

     

    读取模式(Schema)要素

    在读取数据要素前,不需要强制读取模式要素仍然可以连续读取数据要素,每次调用readSchema方法返回一个schema要素,该方法返回True或False,下面代码将在日志中写入数据集的所有模式要素:

    Public Sub LogSchemaFeatures()
        Dim bLastSchema As Boolean
        Dim fmeSchemaFeature As FMEOFeature
        bLastSchema = False
        Set fmeSchemaFeature = m_fmeSession.createFeature
        Do While bLastSchema = False
            bLastSchema = m_fmeReader.readSchema(fmeSchemaFeature)
            If bLastSchema = False Then
               Call m_fmeLogfile.logFeature(fmeSchemaFeature, 1, 1)
           End If
         Loop
    End Sub

    读数据要素

    一旦你的程序创建并且打开reader,就准备开始读取数据要素,可以使用read方法,该方法一次返回一个要素,当没有要素被读取时返回TRUE,否则返回FALSE,下面代码示范用reader读取所有要并写入feature vector。

    bEnd = False
    Do While bEnd = False
        Set fmeDataFeature = m_fmeSession.createFeature
        bEnd = m_fmeReader.read(fmeDataFeature)
        If bEnd = False Then
            Call fmeFeatureVector.append(fmeDataFeature)
        End If
    Loop

    注意:每次调用read方法前都新建一个FMEOFeature对象,为了防止覆盖前一次读取的要素。

     

    使用约束

    通过执行简单的空间查询和属性查询,限制FME对象仅读取匹配的要素,在最后一个要素读取后,你的应用程序可以对输入要素使用setConstraints方法开始新的过滤。

    通过setConstraints方法给FMEOFeature对象指定约束,用属性指定过滤用fme_search_type,下表为fme_search_type支持的值:

    image

    如果你的应用程序多次过滤输入数据集,则强烈建议你当创建reader时打开缓存。

    打开缓存后,所有的输入要素将在第一次读取时被缓存,setConstraints方法在被调用前,将从缓存里创建新的reader。

    当处理的原数据集有空间索引(例如:SDE),则缓存的使用则有所不同。

    关闭Reader

    用close方法关闭

    Call m_fmeReader.Close

    关闭后你可以请求Visual Basic销毁对象引用

    Set m_fmeReader=Nothing

    这将导致释放reader的相关资源。

    参考资料:

    《Building Applications with FME Objects》February 2005

    转载请注明文章来源 http://www.cnblogs.com/booolee

  • 相关阅读:
    常用python机器学习库总结
    链接器link.exe 编译器cl.exe 资源编译器rc.exe
    LRESULT与wParam和lParam的问题
    CreateDialog和DialogBox
    如何通俗易懂地解释卷积?
    深度学习在graph上的使用
    一文弄懂神经网络中的反向传播法——BackPropagation
    WM_COMMAND消息
    win32编程中消息循环和WndProc()窗口过程函数
    使用UEditor 的时候,ajax注意使用同步的方法
  • 原文地址:https://www.cnblogs.com/booolee/p/1548643.html
Copyright © 2011-2022 走看看