zoukankan      html  css  js  c++  java
  • gnucom.cc — Using the Stanford Parser with Jython.

    gnucom.cc — Using the Stanford Parser with Jython.

    Using the Stanford Parser with Jython.

    The following code is a Jython adaptation of the example Java code that comes with the Stanford Parser. I felt like this would be pretty useful to have as a resource because Python doesn’t have a parser that generates grammatical relationships in a sentence, and I wasn’t able to find any example code to help developers get started.

    import sys
    sys.path.append('/path/to/jar/stanford-parser-2008-10-26.jar')
     
    from java.io import CharArrayReader
    from edu.stanford.nlp import *
     
    lp = parser.lexparser.LexicalizedParser('/path/to/englishPCFG.ser.gz')
    tlp = trees.PennTreebankLanguagePack()
    lp.setOptionFlags(["-maxLength", "80", "-retainTmpSubcategories"])
     
    sentence = 'One of my favorite features of functional programming \
    languages is that you can treat functions like values.'
     
    toke = tlp.getTokenizerFactory().getTokenizer(CharArrayReader(sentence));
    wordlist = toke.tokenize()
     
    if (lp.parse(wordlist)):
    	parse = lp.getBestParse()
     
    gsf = tlp.grammaticalStructureFactory()
    gs = gsf.newGrammaticalStructure(parse)
    tdl = gs.typedDependenciesCollapsed()
     
    print parse.toString() 
    print tdl

    Using Jython one can easily generate structural and grammatical parse trees! The code here produces the following structural output. The context-free grammar is easy to analyze and easy to use. There is no end to how you can use this data in your application.

    (ROOT
      (S [126.504]
        (NP [70.320]
          (NP [8.540] (CD [4.252] One))
          (PP [61.414] (IN [0.666] of)
            (NP [59.002]
              (NP [26.440] 
                (PRP$ [3.699] my) 
                (JJ [8.020] favorite) 
                (NNS [8.095] features))
              (PP [32.021] (IN [0.666] of)
                (NP [30.954] (JJ [8.203] functional) 
                  (NN [8.844] programming) 
                  (NNS [9.164] languages))))))
        (VP [53.354] (VBZ [0.144] is)
          (SBAR [47.716] (IN [0.637] that)
            (S [46.752]
              (NP [4.591] (PRP [3.341] you))
              (VP [41.830] (MD [2.354] can)
                (VP [37.270] (VB [7.289] treat)
                  (NP [10.882] (NNS [8.323] functions))
                  (PP [16.113] (IN [5.239] like)
                    (NP [10.201] (NNS [7.216] values))))))))
        (. [0.002] .)))

    In addition to the structural output, the code also produces the grammatical relations in the sentence. These relationships can be used to easily and accurately pick out the subjects, modifiers, and objects in any correctly formatted sentence. If semantic meaning and understanding is something that your application requires, this is the best tool to use.

    [nsubj(is-10, One-1), 
    poss(features-5, my-3), 
    amod(features-5, favorite-4), 
    prep_of(One-1, features-5), 
    amod(languages-9, functional-7), 
    nn(languages-9, programming-8), 
    prep_of(features-5, languages-9), 
    complm(treat-14, that-11), 
    nsubj(treat-14, you-12), 
    aux(treat-14, can-13), 
    ccomp(is-10, treat-14), 
    dobj(treat-14, functions-15), 
    prep_like(treat-14, values-17)]

    Looking for the Stanford Parser files? You can get them from their home page at http://nlp.stanford.edu/software/lex-parser.shtml#Download. Hope that this code helps you get started and if you have any questions about using the Stanford Parser I would be glad to help you.

  • 相关阅读:
    JSP的动态Include的静态Include
    JAVA观察者模式
    JAVA单例模式
    【转】 linux 安装nginx及编译参数详解
    【转】Linux下nginx配置https协议访问的方法
    【转】./configure && make && make install详解
    【转】linux下如何查看某个软件 是否安装?安装路径在哪
    【转发】查看Linux版本系统信息方法汇总
    【转发】CentOS 7 巨大变动之 systemd 取代 SysV的Init
    【转发】centos 7安装完后出现please make your choice from '1' ......
  • 原文地址:https://www.cnblogs.com/lexus/p/2777740.html
Copyright © 2011-2022 走看看