CS 330 Programming Languages 10 / 07 / 2008 Instructor: Michael Eckmann.

Slides:



Advertisements
Similar presentations
Arrays A list is an ordered collection of scalars. An array is a variable that holds a list. Arrays have a minimum size of 0 and a very large maximum size.
Advertisements

CS 206 Introduction to Computer Science II 02 / 27 / 2009 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 01 / 20 / 2009 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 03 / 04 / 2009 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 27 / 2007 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 03 / 02 / 2009 Instructor: Michael Eckmann.
CS 330 Programming Languages 12 / 12 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 09 / 25 / 2006 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 09 / 14 / 2009 Instructor: Michael Eckmann.
CS 330 Programming Languages 10 / 14 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 04 / 2008 Instructor: Michael Eckmann.
CS 898N – Advanced World Wide Web Technologies Lecture 8: PERL Chin-Chih Chang
CS 330 Programming Languages 10 / 16 / 2008 Instructor: Michael Eckmann.
CS 330 Programming Languages 10 / 11 / 2007 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 13 / 2007 Instructor: Michael Eckmann.
CS 330 Programming Languages 11 / 20 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 25 / 2008 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 10 / 14 / 2009 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 10 / 13 / 2008 Instructor: Michael Eckmann.
CS 330 Programming Languages 11 / 18 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 22 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 28 / 2007 Instructor: Michael Eckmann.
CS 330 Programming Languages 10 / 10 / 2006 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 03 / 16 / 2009 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 07 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 30 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 20 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 09 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 03 / 2008 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 30 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 08 / 2010 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 24 / 2010 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 23 / 2008 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 10 / 16 / 2009 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 10 / 08 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 19 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 15 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 23 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 09 / 28 / 2007 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 02 / 25 / 2009 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 16 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 17 / 2008 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 10 / 28 / 2009 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 25 / 2008 Instructor: Michael Eckmann.
Subroutines and Files Bioinformatics Ellen Walker Hiram College.
CS 106 Introduction to Computer Science I 03 / 19 / 2007 Instructor: Michael Eckmann.
CS 330 Programming Languages 11 / 21 / 2006 Instructor: Michael Eckmann.
CS 330 Programming Languages 11 / 13 / 2008 Instructor: Michael Eckmann.
Chapter 10: BASH Shell Scripting Fun with fi. In this chapter … Control structures File descriptors Variables.
CS 206 Introduction to Computer Science II 02 / 23 / 2009 Instructor: Michael Eckmann.
7 1 User-Defined Functions CGI/Perl Programming By Diane Zak.
Computer Programming for Biologists Class 3 Nov 13 th, 2014 Karsten Hokamp
CS 376b Introduction to Computer Vision 01 / 23 / 2008 Instructor: Michael Eckmann.
CS 330 Programming Languages 10 / 02 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 29 / 2007 Instructor: Michael Eckmann.
Perl Tutorial. Why PERL ??? Practical extraction and report language Similar to shell script but lot easier and more powerful Easy availablity All details.
Scripting Languages Diana Trandab ă ț Master in Computational Linguistics - 1 st year
CS 106 Introduction to Computer Science I 09 / 26 / 2007 Instructor: Michael Eckmann.
Introduction to Perl. What is Perl Perl is an interpreted language. This means you run it through an interpreter, not a compiler. Similar to shell script.
CS 106 Introduction to Computer Science I 02 / 01 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 02 / 2007 Instructor: Michael Eckmann.
Standard Types and Regular Expressions CS 480/680 – Comparative Languages.
CS 330 Programming Languages 11 / 15 / 2007 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 10 / 10 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 22 / 2010 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 25 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 09 / 10 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 08 / 2007 Instructor: Michael Eckmann.
CS 330 Programming Languages 09 / 30 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 10 / 2007 Instructor: Michael Eckmann.
Presentation transcript:

CS 330 Programming Languages 10 / 07 / 2008 Instructor: Michael Eckmann

Michael Eckmann - Skidmore College - CS Fall 2008 Today’s Topics Questions / comments? Anyone try the tutorial? Perl –More about Regular expressions

Perl Michael Eckmann - Skidmore College - CS Fall 2008 In terms of regular expression repetition quantifiers, what does greedy mean? A quantifier is greedy if it matches as much of the string as possible while still allowing the whole regular expression to match. We'll see that greediness in action now. Let’s continue looking at this site for examples of matching repetitions and the 4 principles that are followed:

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Recap on the special variables we learned $_ $` $& and $' (left, match, right)‏ $0 (program name)‏ $1, $2, $3,... (the submatches)‏

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Let's write a few regular expressions. match any signed or unsigned integers of arbitrary length. e.g. it should match –-22 –4567 –1 –+43 but not things like: –- –+ –4.56 –abcd –etc.

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Let's try these: 1) ignore beginning whitespace if there is any, and match the word program and store the rest of the string (after the word program) into some variable. 2) Now what if there were \n's in the string? What might we change? 3) cs330 or cs106 or CS106 or CS330 but not Cs330, or cS106 etc.

Perl Michael Eckmann - Skidmore College - CS Fall ) ignore beginning whitespace if there is any, and match the word program and store the rest of the string (after the word program) into some variable. m/\s*program(.*)/ 2) Now what if there were \n's in the string? What might we change? m/\s*program(.*)/s 3) cs330 or cs106 or CS106 or CS330 but not Cs330, or cS106 etc. m/cs330|cs106|CS330|CS106/ OR m/(cs|CS)(106|330)/

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Let’s look at a larger parsing example using many of the features we just learned. We'll read the problem and try to solve it ourselves before looking at the solution. The “doing string selections” section of: The following page is a good page for reference. It is a nice summary of the different characters and their meanings with succinct examples:

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Declaring and defining subroutines sub name { # code goes here… } Call subroutines &name; &name( parm1, parm2, parm3); # any number of parameters allowed separated by commas name(parm1, parm2, parm3); # the ampersand is optional if using parameters in parentheses.

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Parameters in subroutines are stored in a parameter The value returned from a subroutine is the value of the last evaluation done inside it. Be aware of this! Or you can explicitly use the return function to return a value and terminate the subroutine. Local variables in subroutines are declared by using the my keyword –When declaring more than one, you must put them in parentheses or else all but the first one will be considered global. –my ($parm1, $parm2); When calling the subroutine, the arguments passed in are put in special array for that subroutine.

Perl Michael Eckmann - Skidmore College - CS Fall 2008 There are a multitude of ways to get at the contents of the elements in the parameter One of which is $_[0], $_[1], etc... Note well: These have NOTHING to do with the $_ special default variable which we have seen. Another way is to use shift. Shift will shift in the next array element into the variable on the LHS and remove that element from the array. e.g. my $filehand = shift; note: shift works for any array, not just the paramater array. e.g. Another way would be to do something like: my ($age, $height, $weight)

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Common code problems I saw last year. Not using chomp on the input (and then comparing the input variable to some string that doesn’t have a newline after it.)‏ Comparing strings using ==, !=, etc. instead of the correct way which is to use eq, ne, etc. When comparing non-numeric strings to numerics, the strings are evaluated as zero which trips people up. Solution would be to: Use chomp on the input variable Use the string comparison operators to compare strings (don’t use ==, !=,,etc. which should only be used to compare numeric data.)‏

Perl Michael Eckmann - Skidmore College - CS Fall 2008 Let's start to implement a recursive descent parser for the language in the text book (p. 185) What are the features of a recursive decent parser again? Assuming the thing we're parsing is stored in a file we would like to read in the whole file in one string (including \n's). The reason the reading of a file reads one line at a time is because Perl has a special variable, $/, that holds what “termination character(s)” which in our case is usually set to be “\n”. We can temporarily store what the termination character(s) are, then undef the $/, then read the whole file into a scalar and then store the termination characters back into $/.

Perl Michael Eckmann - Skidmore College - CS Fall 2008 There's so much more about Perl that I haven't gone over. You should now be able to learn more on your own. There are many functions I haven't gone over that are useful –Substring –Split –Etc. –Find out about the functions (with examples) at these 2 pages: – –