Skip to content

Latest commit

 

History

History
211 lines (137 loc) · 9.05 KB

02_wildcards_shortcuts.md

File metadata and controls

211 lines (137 loc) · 9.05 KB
title author date
Shell for Bioinformatics
Sheldon McKay, Mary Piper, Radhika Khetani, Meeta Mistry, Jihe Liu
August 7, 2017

Wildcards and Shortcuts in Shell

Learning Objectives

  • Implement tab completion when writing paths
  • Use of the asterisk * wildcard to select multiple items
  • List a few shortcuts

Are you logged into O2 and on a compute node?

You need to be logged into O2, and be on a compute node to run through this lesson. If you are, please proceed to the next section!

If you are not logged into O2 or are not on a compute node, please follow the steps below as appropriate:

  1. Log in using ssh [email protected] and enter your password (HMSXXcluster) (replace the "XX" with the number you were assigned in class)
  2. Once you are on the login node, use srun --pty -p interactive -t 0-2:30 --mem 1G /bin/bash to get on a compute node.
  3. Proceed to the next section once your command prompt has the word compute in it.

Saving time with wildcards and other shortcuts

Wild cards

The "*" wildcard:

Navigate to the ~/unix_lesson/raw_fastq directory. This directory contains FASTQ files from a next-generation sequencing dataset.

The "*" character is a shortcut for "everything". Thus, if you enter ls *, you will see all of the contents of a given directory. Now try this command:

$ ls *fq

This lists every file that ends with a fq. Try this command:

$ ls /usr/bin/*.sh

This lists every file in /usr/bin directory that ends in the characters .sh. "*" can be placed anywhere in your pattern. For example:

$ ls Mov10*fq

This lists only the files that begin with 'Mov10' and end with fq.

So how does this actually work? The Shell (bash) considers an asterisk "*" to be a wildcard character that can match one or more occurrences of any character, including no character.

Tip - An asterisk/star is only one of the many wildcards in Unix, but this is the most powerful one and we will be using this one the most for our exercises.

The "?" wildcard:

Another wildcard that is sometimes helpful is ?. ? is similar to * except that it is a placeholder for exactly one position. Recall that * can represent any number of following positions, including no positions. To highlight this distinction lets look at a few examples. First, try this command:

ls /bin/d*

This will display all files in /bin/ that start with "d" regardless of length. However, if you only wanted the things in /bin/ that start with "d" and are two characters long then you can use:

ls /bin/d?

Lastly, you can chain together multiple "?" marks to help specify a length. In the example below, you would be looking for all things in /bin/ that start with a "d" and have a name length of three characters.

ls /bin/d??


Exercise

Do each of the following using a single ls command without navigating to a different directory.

  1. List all of the files in /bin that start with the letter 'c'

  2. List all of the files in /bin that contain the letter 'a'

  3. List all of the files in /bin that end with the letter 'o'

  4. BONUS: Using one command to list all of the files in /bin that contain either 'a' or 'c'. (Hint: you might need to use a different wildcard here. Refer to this post for some ideas.)

    Answers


    Click each question below to reveal the answer.

    Question 1 ls /bin/c*
    Question 2 ls /bin/*a*
    Question 3 ls /bin/*o
    BONUS ls /bin/*[ac]*

Shortcuts

There are some very useful shortcuts that you should also know about.

Home directory or "~"

Dealing with the home directory is very common. In shell, the tilde character, "~", is a shortcut for your home directory. Let's first navigate to the raw_fastq directory (try to use tab completion here!):

$ cd
$ cd unix_lesson/raw_fastq

Then enter the command:

$ ls ~

This prints the contents of your home directory, without you having to type the full path. This is because the tilde "~" is equivalent to "/home/username", as we had mentioned in the previous lesson.

Parent directory or ".."

Another shortcut you encountered in the previous lesson is "..":

$ ls ..

The shortcut .. always refers to the parent directory of whatever directory you are in currently. So, ls .. will print the contents of unix_lesson. You can also chain these .. together, separated by /:

$ ls ../..

This prints the contents of /home/username, which is two levels above your current directory (your home directory).

Current directory or "."

Finally, the special directory . always refers to your current directory. So, ls and ls . will do the same thing - they print the contents of the current directory. This may seem like a useless shortcut, but recall that we used it earlier when we copied over the data to our home directory.

To summarize, the commands ls ~, ls ~/., and ls /home/username all do exactly the same thing. These shortcuts can be convenient when you navigate through directories!

Command History

You can easily access previous commands by hitting the up arrow key on your keyboard, this way you can step backwards through your command history. On the other hand, the down arrow key takes you forward in the command history.

Try it out! While on the command prompt hit the up arrow a few times, and then hit the down arrow a few times until you are back to where you started.

You can also review your recent commands with the history command. Just enter:

$ history

You should see a numbered list of commands, including the history command you just ran!

Only a certain number of commands can be stored and displayed with the history command by default but you can increase or decrease it to a different number. It is outside the scope of this workshop, but feel free to look it up after class.

NOTE: So far we have only run very short commands that have very few or no arguments. It would be faster to just retype it than to check the history. However, as you start to run analyses on the command-line you will find that the commands are longer and more complex, and the history command will be very useful then!

Cancel a command

Sometimes as you enter a command, you realize that you don't want to continue or run the current line. Instead of deleting everything you have entered (which could be very long), you could quickly cancel the current line and start a fresh prompt with Ctrl + C.

$ # Run some random words, then hit "Ctrl + C". Observe what happens

Other handy command-related shortcuts

  • Ctrl + A will bring you to the start of the command you are writing.
  • Ctrl + E will bring you to the end of the command.

Exercise

  1. Checking the output of the history command, how many commands have you typed in so far?
  2. Use the up arrow key to check the command you typed before the history command. What is it? Does it make sense?
  3. Type several random characters on the command prompt. Can you bring the cursor to the start with Ctrl + A? Next, can you bring the cursor to the end with Ctrl + E? Finally, what happens when you use Ctrl + C?

Summary: Commands, options, and keystrokes covered

~           # home dir
.           # current dir
..          # parent dir
*           # wildcard
ctrl + c    # cancel current command
ctrl + a    # start of line
ctrl + e    # end of line
history

This lesson has been developed by members of the teaching team at the Harvard Chan Bioinformatics Core (HBC). These are open access materials distributed under the terms of the Creative Commons Attribution license (CC BY 4.0), which permits unrestricted use, distribution, and reproduction in any medium, provided the original author and source are credited.