jagomart
digital resources
picture1_Python Pdf 180352 | Nlp Lab05


 192x       Filetype PDF       File size 0.09 MB       Source: web.cs.dal.ca


File: Python Pdf 180352 | Nlp Lab05
lab5p 1 faculty of computer science dalhousie university 11 14 oct 2022 csci4152 6509 naturallanguageprocessing lab5 pythonnltktutorial1 labinstructor stacey taylor location goldberg cs 134 u cs 143 g notes author ...

icon picture PDF Filetype PDF | Posted on 30 Jan 2023 | 2 years ago
Partial capture of text on file.
                                                                                                                                                                                                                                  Lab5p.1
                                       Faculty of Computer Science, Dalhousie University                                                                                                                   11/14-Oct-2022
                                       CSCI4152/6509—NaturalLanguageProcessing
                                       Lab5: PythonNLTKTutorial1
                                       LabInstructor: Stacey Taylor
                                       Location: Goldberg CS 134(u)/CS 143(g)
                                       Notes author: Dijana Kosmajac, Vlado Keselj
                                      PythonNLTKTutorial1
                                      LabOverview
                                             – Introduction to Natural Language Toolkit (NLTK)
                                             – Python quick overview;
                                             – Lexical analysis: Word and text tokenizer;
                                             – n-gram and collocations;
                                             – NLTKcorpora;
                                                       ¨
                                             – Naıve Bayes classifier with NLTK.
                                      Files to be submitted:
                                            1. lab5-list_merge.py
                                            2. lab5-stop_word_removal.py
                                            3. lab5-explore_corpus.py
                                            4. lab5-movie_rev_classifier.py
                                      This is the first of three Python tutorials in the course. Many students may have seen Python before, so to make it
                                      moreinteresting and novel we will also use Python in the context of some NLP tasks, and use some NLP libraries.
                                      Fromthestart and this lab, we will use the NLTK Python library (Natural Language Toolkit).
                                      WhatisNLTK?
                                      Natural Language Toolkit (NLTK) is a popular platform for building Python programs to work with human language
                                      data; i.e., for Natural Language Processing. It is accompanied by a book that explains the underlying concepts
                                      behind the language processing tasks supported by the toolkit. NLTK is intended to support research and teaching
                                      in NLP or closely related areas, including empirical linguistics, cognitive science, artificial intelligence, information
                                      retrieval, and machine learning.
                                      Wewillstart with a quick Python introduction, but if you would like to learn more about Python, there are many
                                      resources on the Web and books. For a simple beginner Python tutorial take a look at:
                                      http://www.tutorialspoint.com/python/python_tutorial.pdf
                                      Asinprevious labs, we will login to the server timberlea for this lab, which has the NLTK install. If you want
                                      to install NLTK to your local machine, you can refer to the following URLs:
                                      http://www.nltk.org/install.html
                                      http://www.nltk.org/data.html
                                      In this lab we will explore:
                                             – Python quick overview;
                                             – Lexical analysis: Word and text tokenizer;
                                             – n-gram and collocations;
                                      October 11, 2022, CSCI 4152/6509   http://web.cs.dal.ca/ vlado/csci6509/
                                                                                                     ˜
                    Lab5p.2                                                                                    CSCI4152/6509
                        – NLTKcorpora;
                             ¨
                        – Naıve Bayes classifier with NLTK.
                    Pythonoverview
                    Basic syntax
                    Identifiers:   Python identifier is a name used to identify a variable, function, class, module, or other object. An
                    identifier starts with a letter A to Z or a to z, or an underscore ( ) followed by zero or more letters, underscores and
                    digits (0 to 9). Other characters are not allowed in identifiers, so be careful not to start variables as in Perl with
                    special characters @, $, or %. The identifiers are case-sensitive, so for example, Variable and variable are
                    two different identifiers.
                    Lines and Indentation:   Python provides no braces to indicate blocks of code for class and function definitions or
                    flowcontrol. Blocks of code are denoted by line indentation, which is rigidly enforced. The number of spaces in the
                    indentation is variable, but all statements within the block must be indented the same amount.
                    Quotation:   Python accepts single (’), double (") and triple (’’’ or """) quotes to denote string literals, as long
                    as the same type of quote starts and ends the string. Example:
                    word = ’word’
                    sentence = "This is a sentence."
                    paragraph = """This is a paragraph. It is
                                         made up of multiple lines and sentences."""
                    Datatypes, assigning and deleting values:   Python has five standard data types:
                        – numbers;
                        – strings;
                        – lists;
                        – tuples;
                        – dictionaries.
                    Pythonvariables do not need explicit declaration to reserve memory space. The declaration happens automatically
                    whenyouassign a value to a variable. The equal sign (=) is used to assign values to variables. The operand to the
                    left of the = operator is the name of the variable and the operand to the right of the = operator is the value stored in
                    the variable. For example:
                    counter = 100           # An integer assignment
                    miles = 1000.0          # A floating point
                    name = "John"           # A string
                    Lists
                    print(len([1, 2, 3]))                    # 3 - length
                    print([1, 2, 3] + [4, 5, 6]) # [1, 2, 3, 4, 5, 6] - concatenation
                    print([’Hi!’] * 4)                       # [’Hi!’, ’Hi!’, ’Hi!’, ’Hi!’]
                                                             #   - repetition
                    print(3 in [1, 2, 3])                    # True - checks membership
                    for x in [1, 2, 3]: print(x) # 1 2 3 - iteration
                   CSCI4152/6509                                                                             Lab5p.3
                   Someoftheusefulbuilt-in functions useful in work with lists are max, min, cmp, len, list (converts tuple to
                   list), etc.
                   Someofthelist-specific functions are list.append, list.extend, list.count, etc.
                   Tuples
                   tup1 = (’physics’, ’chemistry’, 1997, 2000);
                   tup2 = (1, 2, 3, 4, 5, 6, 7);
                   print(tup1[0])            # prints: physics
                   print(tup2[1:5])          # prints: [2, 3, 4, 5]
                   Basic tuple operations are same as with lists: length, concatenation, repetition, membership and iteration.
                   Dictionaries
                   dict = {’Name’:’Zara’, ’Age’:7, ’Class’:’First’}
                   dict[’Age’] = 8                        # update existing entry
                   dict[’School’] = "DPS School" # Add new entry
                   del dict[’School]                      # Delete existing entry
                   List comprehension.  Comprehensions are constructs that allow sequences to be built from other sequences.
                   Python 2.0 introduced list comprehensions and Python 3.0 comes with dictionary and set comprehensions. The
                   following is the example:
                   a_list = [1, 2, 9, 3, 0, 4]
                   squared_ints = [e 2 for e in a_list]
                                         **
                   print(squared_ints)                 # [ 1, 4, 81, 9, 0, 16 ]
                   This is same as:
                   a_list = [1, 2, 9, 3, 0, 4]
                   squared_ints = []
                   for e in a_list:
                        squared_ints.append(e         2)
                                                   **
                   print(squared_ints)                 # [ 1, 4, 81, 9, 0, 16 ]
                   Now, let us see an example with the ‘if’ statement. The example shows how to filter out non integer types from
                   mixed list and apply operations.
                   a_list = [1, ’4’, 9, ’a’, 0, 4]
                   squared_ints = [ e 2 for e in a_list if type(e) is int ]
                                          **
                   print(squared_ints)                # [ 1, 81, 0, 16 ]
                   However, if you want to include an ‘if-else’ statement, the arrangement looks a bit different.
                   a_list = [1, ’4’, 9, ’a’, 0, 4]
                   squared_ints = [ e 2 if type(e) is int else ’x’ for e in a_list]
                                          **
                   print(squared_ints)                # [1, ’x’, 81, ’x’, 0, 16]
                    Lab5p.4                                                                                      CSCI4152/6509
                    Youcanalsogenerate dictionary using list comprehension:
                    a_list = ["I", "am", "a", "data", "scientist"]
                    science_list = { e:i for i, e in enumerate(a_list) }
                    print(science_list)             # {’I’: 0, ’am’: 1, ’a’: 2, ’data’: 3,
                                                    #   ’scientist’: 4}
                    . . . or list of tuples:
                    a_list = ["I", "am", "a", "data", "scientist"]
                    science_list = [ (e,i) for i, e in enumerate(a_list) ]
                    print(science_list)             # [(’I’, 0), (’am’, 1), (’a’, 2),
                                                    # (’data’, 3), (’scientist’, 4)]
                    String handling
                    Examples with string operations:
                    str = ’Hello World!’
                    print(str)                   # Prints complete string
                    print(str[0])                # Prints first character of the string
                    print(str[2:5])              # Prints characters starting from 3rd to 5th
                    print(str[2:])               # Prints string starting from 3rd character
                    print(str 2)                 # Prints string two times
                                 *
                    print(str + "TEST") # Prints concatenated string
                    Other useful functions include join, split, count, capitalize, strip, upper, lower, etc.
                    Exampleofstring formatting:
                    print("My name is %s and age is %d!" % (’Zara’,21))
                    IOhandling
                    Python has two major versions which have some significant differences: Python 2 and Python 3. The default version
                    that we will use is Python 3. One of the differences is the input function, which is called raw_input in Python 2
                    and is renamed to input in Python 3.
                    str = input("Enter your input: ")
                    print("Received input is : ", str)
                    File opening.   Tohandle files in Python, you can use function open. Syntax:
                    file object = open(file_name [, access_mode][, buffering])
                    Oneoftheuseful packages for handling tsv and csv files is csv library.
The words contained in this file might help you see if this file matches what you are looking for:

...Labp faculty of computer science dalhousie university oct csci naturallanguageprocessing lab pythonnltktutorial labinstructor stacey taylor location goldberg cs u g notes author dijana kosmajac vlado keselj laboverview introduction to natural language toolkit nltk python quick overview lexical analysis word and text tokenizer n gram collocations nltkcorpora nave bayes classier with files be submitted list merge py stop removal explore corpus movie rev classifier this is the rst three tutorials in course many students may have seen before so make it moreinteresting novel we will also use context some nlp tasks libraries fromthestart library whatisnltk a popular platform for building programs work human data i e processing accompanied by book that explains underlying concepts behind supported intended support research teaching or closely related areas including empirical linguistics cognitive articial intelligence information retrieval machine learning wewillstart but if you would like l...

no reviews yet
Please Login to review.