Start learning with our library of video tutorials taught by experts. Get started

Foundations of Programming: Fundamentals
Watching:

Finding patterns in strings


From:

Foundations of Programming: Fundamentals

with Simon Allardice
Expand all | Collapse all
  1. 4m 14s
    1. Welcome
      1m 16s
    2. Making the most of this course
      2m 8s
    3. Using the exercise files
      50s
  2. 22m 11s
    1. What is programming?
      5m 45s
    2. What is a programming language?
      4m 48s
    3. Writing source code
      5m 34s
    4. Compiled and interpreted languages
      6m 4s
  3. 16m 29s
    1. Why JavaScript?
      4m 45s
    2. Creating your first program in JavaScript
      6m 54s
    3. Requesting input
      4m 50s
  4. 31m 38s
    1. Introduction to variables and data types
      5m 16s
    2. Understanding strong, weak, and duck-typed languages
      3m 51s
    3. Working with numbers
      5m 4s
    4. Using characters and strings
      4m 5s
    5. Working with operators
      4m 47s
    6. Properly using white space
      6m 46s
    7. Adding comments to code for human understanding
      1m 49s
  5. 24m 49s
    1. Building with the if statement
      7m 35s
    2. Working with complex conditions
      4m 10s
    3. Setting comparison operators
      6m 59s
    4. Using the switch statement
      6m 5s
  6. 17m 56s
    1. Breaking your code apart
      4m 1s
    2. Creating and calling functions
      2m 57s
    3. Setting parameters and arguments
      6m 7s
    4. Understanding variable scope
      2m 23s
    5. Splitting code into different files
      2m 28s
  7. 13m 32s
    1. Introduction to iteration
      4m 28s
    2. Writing a while statement
      5m 24s
    3. Creating a for loop
      3m 40s
  8. 19m 28s
    1. Cleaning up with string concatenation
      4m 30s
    2. Finding patterns in strings
      8m 3s
    3. Introduction to regular expressions
      6m 55s
  9. 19m 59s
    1. Working with arrays
      5m 47s
    2. Array behavior
      5m 29s
    3. Iterating through collections
      5m 18s
    4. Collections in other languages
      3m 25s
  10. 10m 50s
    1. Programming style
      5m 55s
    2. Writing pseudocode
      4m 55s
  11. 25m 55s
    1. Input/output and persistence
      3m 6s
    2. Reading and writing from the DOM
      8m 11s
    3. Event driven programming
      7m 47s
    4. Introduction to file I/O
      6m 51s
  12. 24m 26s
    1. Introduction to debugging
      5m 57s
    2. Tracing through a section of code
      7m 5s
    3. Understanding error messages
      3m 21s
    4. Using debuggers
      8m 3s
  13. 14m 17s
    1. Introduction to object-oriented languages
      5m 18s
    2. Using classes and objects
      6m 29s
    3. Reviewing object-oriented languages
      2m 30s
  14. 11m 14s
    1. Memory management across languages
      5m 11s
    2. Introduction to algorithms
      4m 2s
    3. Introduction to multithreading
      2m 1s
  15. 29m 20s
    1. Introduction to languages
      1m 42s
    2. C-based languages
      4m 40s
    3. The Java world
      3m 13s
    4. .NET languages: C# and Visual Basic .NET
      6m 17s
    5. Ruby
      3m 4s
    6. Python
      2m 56s
    7. Objective-C
      4m 3s
    8. Libraries and frameworks
      3m 25s
  16. 1m 2s
    1. Where to go from here
      1m 2s

Video: Finding patterns in strings

A little earlier in the course I talked about strings in JavaScript and in a lot of other languages being smart, being able to tell us information about themselves, and even having behavior. An example of this would be if I created a variable called phrase and gave it this simple value. I can then use the name of the variable, followed with a dot, and then I can access certain built-in information about it. So I am using this .length, what's called a global property, to access this fact that it's 24 characters long, and we can pop that up in an alert box.

Watch this entire course now—plus get access to every course in the library. Each course includes high-quality videos taught by expert instructors.

Become a member
Please wait...
Foundations of Programming: Fundamentals
4h 47m Beginner Sep 22, 2011

Viewers: in countries Watching now:

This course provides the core knowledge to begin programming in any language. Simon Allardice uses JavaScript to explore the core syntax of a programming language, and shows how to write and execute your first application and understand what's going on under the hood. The course covers creating small programs to explore conditions, loops, variables, and expressions; working with different kinds of data and seeing how they affect memory; writing modular code; and how to debug, all using different approaches to constructing software applications.

Finally, the course compares how code is written in several different languages, the libraries and frameworks that have grown around them, and the reasons to choose each one.

Topics include:
  • Writing source code
  • Understanding compiled and interpreted languages
  • Requesting input
  • Working with numbers, characters, strings, and operators
  • Writing conditional code
  • Making the code modular
  • Writing loops
  • Finding patterns in strings
  • Working with arrays and collections
  • Adopting a programming style
  • Reading and writing to various locations
  • Debugging
  • Managing memory usage
  • Learning about other languages
Subjects:
Developer Web Programming Foundations
Author:
Simon Allardice

Finding patterns in strings

A little earlier in the course I talked about strings in JavaScript and in a lot of other languages being smart, being able to tell us information about themselves, and even having behavior. An example of this would be if I created a variable called phrase and gave it this simple value. I can then use the name of the variable, followed with a dot, and then I can access certain built-in information about it. So I am using this .length, what's called a global property, to access this fact that it's 24 characters long, and we can pop that up in an alert box.

Well, it goes a little deeper than this. If I'm working with a string in JavaScript that also has behavior and we can use the same dot operator to get to that. Strings have what are called methods and these are like functions. We've already seen functions. We call them with parentheses, but methods are like functions that belong to a string. So again, if we create a variable called phrase, what I can do is use a phrase., and then some built-in methods like toUpperCase, which I'm calling like a function using the parentheses after it.

Now because I have this in an alert box what we are going to get is that string converted to uppercase. Now I am not going to dive into every behavior that strings have. These change across different languages, but you will find in most of them strings are quite powerful and they have various built-in behaviors like converting to uppercase or converting to lowercase or allowing us to find certain pieces within them. Now a couple of things to understand about strings, where they do become a bit more complex than numbers, is because we can obviously have strings using different cases.

If I create two variables, one containing the word Hello with an uppercase H and the other containing the word hello with a lowercase h, and then I want to see if they are equal to each other, well, they won't be, because uppercase H and lowercase H are not equal. But perhaps what I want to do is a case insensitive comparison. I don't really care whether it's the uppercase or lowercase. I just want to know if the same word is in them. Well, the fact that I can use these variables and convert them means that what I could do is something that might look a little annoying here, but I'm asking if the str1 converted toLowerCase is equal to str2, converted toLowerCase, then I can ask, are they actually equal? And this is a great ability of being able to ask strings to do things for us.

One step further is we can find certain words that exist inside of strings. This is very, very common to want to do. So we create a variable called phrase and then what I am using is what's called the indexOf method of the string. I am using that same dot operator and then indexOf. It's an lowercase i and an uppercase O, and I am passing in another string. In this case I am passing in the word groovy, and I want to find out what is the index of groovy? Meaning, if it exists, where does it begin in the string? Now what's going to happen is if that word exists in the first string, it's going to return the position and that's zero based.

So the first letter of the string, which is the uppercase W, will be positioned 0. Groovy will start at position 10. If that word is not found in the string, this will return -1. So if for example, I wanted to find out, if a certain phrase or word did not occur, I could call phrase. indexOf, passing in a DDDD. We know that does not occur. And if the result of that was -1, I could pop up an alert box that says, no, that word does not occur in the string.

And of course, there are dozens of ways that you could combine these different kinds of operations to find out if a phrase was in a string or if it was not in a string, but this is one example of doing this. Now again, in a course like this, I'm not really expecting you to try and memorize this syntax. What I am wanting you to do is understand that this is possible. That understand that, yes, I can find one string and I can see if it exists in another one or I can see if it does not exist in another one. You can always look the syntax up, you can always find cookbooks and examples online, but you need to know that this stuff is possible.

There is also a method called lastIndexOf. Whereas .indexOf will give us the first occurrence of the word in the larger string, .lastIndexOf will give us the last position of that in the string. So if we are working with larger amounts of text that might be useful. We can also start breaking a string apart. There are several methods for this. One of the ones I like is called slice. So we create a variable called phrase, just give it some basic text.

And what I'm going to do is create a new variable called segment based on part of phrase, and I am going to use phrase.slice, and slice expects two arguments. In this case I am some passing in 6,11. What does that mean? What we are going to do is the first number is the position that we are going to start at in the phrase, and it starts from 0, so 0123456, 6 is the o of another. Then 11 would be the position we are going to stop by.

So we are basically going to get 6, 7, 8, 9, 10. We will get those letters and we will store that result in the second variable, and that's how we could pull a section out of another string. There are also methods like .substring() and .substr() that do have similar ways of dealing with this, but they give us a couple of other options. I am a fan of slice, but you can look at the others if you're interested. More than ever what you should be taking from this is not necessarily trying to remember the syntax or remember the exact format, but just understanding the JavaScript, and JavaScript is a pretty lightweight language, has a whole lot of built-in functionality for manipulating strings, for getting to them, for understanding where the other words exist inside them.

You'll find that across all modern programming languages and it can come in very handy. One final thing to explore is the idea of comparing strings, not for equality, but for greater than and less than. We can do this. Let's say we've got a couple of basic strings here, aardvark and beluga. Then I write an if statement. If (str1 < str2). What it's going to do is start comparing the first letters. In this case, really asking is a less than b, almost like a phonebook comparison.

In this case, yes, absolutely! This would be true. However, the fact of adding in the uppercase and lowercase parts of it can make things a bit more confusing, in not necessarily the way you expect. So here in the second example, I have aardvark with a lowercase a, and Beluga with an uppercase B. Again, I ask if there is a comparison? Is str1 < str2? Most people would think, well, yes it is, but here is the problem. This would actually be regarded as false, and that's because as far as the internal structure of how we encode characters in a programming language, the uppercase letters are regarded as less than the lowercase letters.

So uppercase B is regarded as coming before a lowercase a. So this will be false. A technique that I might use to ignore this would be once again using the ability of the string to be converted and calling toLowercase on both of these, before I actually compared the two. So all you can see, there are a few gotchas when dealing with strings and some of the behaviors are not necessarily intuitive when you're new to this. You can also see that strings have a lot of built-in behavior that allows you different ways of dealing with this.

There are currently no FAQs about Foundations of Programming: Fundamentals.

Share a link to this course
Please wait... Please wait...
Upgrade to get access to exercise files.

Exercise files video

How to use exercise files.

Learn by watching, listening, and doing, Exercise files are the same files the author uses in the course, so you can download them and follow along Premium memberships include access to all exercise files in the library.
Upgrade now


Exercise files

Exercise files video

How to use exercise files.

For additional information on downloading and using exercise files, watch our instructional video or read the instructions in the FAQ.

This course includes free exercise files, so you can practice while you watch the course. To access all the exercise files in our library, become a Premium Member.

Upgrade now

Are you sure you want to mark all the videos in this course as unwatched?

This will not affect your course history, your reports, or your certificates of completion for this course.


Mark all as unwatched Cancel

Congratulations

You have completed Foundations of Programming: Fundamentals.

Return to your organization's learning portal to continue training, or close this page.


OK
Become a member to add this course to a playlist

Join today and get unlimited access to the entire library of video courses—and create as many playlists as you like.

Get started

Already a member?

Become a member to like this course.

Join today and get unlimited access to the entire library of video courses.

Get started

Already a member?

Exercise files

Learn by watching, listening, and doing! Exercise files are the same files the author uses in the course, so you can download them and follow along. Exercise files are available with all Premium memberships. Learn more

Get started

Already a Premium member?

Exercise files video

How to use exercise files.

Ask a question

Thanks for contacting us.
You’ll hear from our Customer Service team within 24 hours.

Please enter the text shown below:

The classic layout automatically defaults to the latest Flash Player.

To choose a different player, hold the cursor over your name at the top right of any lynda.com page and choose Site preferencesfrom the dropdown menu.

Continue to classic layout Stay on new layout
Welcome to the redesigned course page.

We’ve moved some things around, and now you can



Exercise files

Access exercise files from a button right under the course name.

Mark videos as unwatched

Remove icons showing you already watched videos if you want to start over.

Control your viewing experience

Make the video wide, narrow, full-screen, or pop the player out of the page into its own window.

Interactive transcripts

Click on text in the transcript to jump to that spot in the video. As the video plays, the relevant spot in the transcript will be highlighted.

Thanks for signing up.

We’ll send you a confirmation email shortly.


Sign up and receive emails about lynda.com and our online training library:

Here’s our privacy policy with more details about how we handle your information.

Keep up with news, tips, and latest courses with emails from lynda.com.

Sign up and receive emails about lynda.com and our online training library:

Here’s our privacy policy with more details about how we handle your information.

   
submit Lightbox submit clicked