Difference between ./ and ~/

When creating filepaths and URLs, I noticed that many times the path starts with ./ or ~/.

What is the difference between filepaths that start with ./ and ~/?

What do each of them mean?


For completeness sake ...

  • path is a file or directory named path in the current directory.
  • ./path is a file or directory named path in the current directory, with the directory spelled out. . is the current directory, and path is the name of the file or directory within the current directory.
  • ~/path is a shorthand for $HOME/path where $HOME is a variable which refers to your home directory. Typically your home directory will be somewhere like /home/you or /Users/you where you is your account name. (The command echo "$HOME" will display your home directory.) The expanded value is an absolute path (unless you have messed up the value of $HOME thoroughly), as indicated by the initial slash.
  • /path is an absolute path which refers to a file or directory named path which is in the root directory /. Every file on Unix is ultimately somewhere in the directory tree which starts with the root directory.

Every file name which begins with / is an absolute path (aka full path) which explains how to reach a particular node starting from the root directory. For example, /var/tmp/you/reminder.txt refers to a file or directory reminder.txt (probably a file, judging from the name; but Unix doesn't care what you call your files or directories) which is in the directory you which is in the directory tmp which is in the directory var which is in the root directory.

Every file name which doesn't begin with / is a relative path which indicates how to reach a particular file or directory starting from the current directory. The special directory .. is the parent directory and the special directory . is the current directory. So path/there refers to the file or directory there inside the directory path in the current directory; and (hover the mouse over the gray area to display the spoiler)

there/.././and/back/.. is a (wicked complicated) way to refer to the directory and in the current directory, where we traverse the there directory and then move back to the current directory; then stay in the current directory; then refer to the directoryback inside the directory and, but then move back to the parent directory of that, ending up with ./and.

In addition to ~/ for the current user's home directory, some shells and applications allow the notation ~them/ to refer to the home directory of the user account them. Also, some web server configurations allow each user to have a public web site in their directory ~/public_html and the URL notation http://server/~them/ would serve up the site of the user account them for outside visitors.

The current directory is a convenience which the shell provides so you don't have to type long paths all the time. You can, if you want to.

/bin/ls /home/you/Documents/unix-101/directories.txt

is a longwinded but perfectly valid way to say (assuming you are in your home directory),

ls Documents/unix-101/directories.txt

You could also say

cd Documents/unix-101
ls directories.txt

and until you cd again, all your commands will run in this directory.

(There is a difference in that ls will print the path of the files you ask it to list, too. So ls directories.txt will simply print directories.txt whereas ls Documents/unix-101/directories.txt will print ... that.)

You can always put an absolute path instead of a relative one, or vice versa; and you generally don't need to cd anywhere in particular (except some basically broken beginner scripts tend to require you to be in a particular directory when you run them).

A common beginner mistake is assuming that the location of a script or an executable dictates where it looks for files; but then if that were true, ls . would display files in the bin directory instead of your current directory, wouldn't it?

When you first log in, the current working directory is set to your home directory.

A "directory" is sometimes called a "folder" by people who are not yet old enough to prefer the former.


Notice how it looks from this like ls has to be a file in the current directory, and yet we also say that it's in /bin? That's a different question (look up $PATH).

When . is not in your PATH (as generally it should not be), you have to say ./scriptname instead of scriptname to run the commands in an executable file called scriptname in the current directory. In other words, this is a corner case were you explicitly have to spell out ./ to specify something in the current directory (or equivalently but verbosely spell out the full absolute path, perhaps with a command substitution $(pwd)/scriptname but this is really pleonastic.)

Also, don't confuse the directory name . with the Bourne shell command which comprises a single dot (also known by its Bash alias source). The command

. ./scriptname

runs the commands from the file ./scriptname in the context of the current shell instance, as opposed to in a separate subshell (which is what just ./scriptname does). In other words, this command line invokes the dot command on a file scriptname in the dot directory.


./ means "starting from the current directory". . refers to the current working directory, so something like ./foo.bar would be looking for a file called foo.bar in the current directory. (As a side note, .. means refers to the parent directory of the current directory. So ../foo.bar would be looking for that file one directory above.)

~/ means "starting from the home directory". This could have different meanings in different scenarios. For example, in a Unix environment ~/foo.bar would be looking for a file called foo.bar in your home directory, something like /home/totzam/foo.bar. In many web applications, ~/foo.bar would be looking for a file called foo.bar in the web application root, something like /var/http/mywebapp/foo.bar.


./ is the current directory

~/ is the home directory of the current user