Stata Tutorial

Stata Tutorial
(Windows version SE 10.1)
Spring 2009
Data and Statistical Services
Social Science Reference Center
Firestone Library
Princeton University
[email protected]
http://dss.princeton.edu
This guide was prepared to give you a basic overview of commands in reading in, examining, analyzing, and
graphing data using Stata. For reading in data, described here use typical data format you may encounter when
downloading data files as examples. In examining, analyzing, and graphing, listed here are some of the most
commonly used commands. In this new edition, I added an equivalent way to submit commands by using menus.
Menus may make it easier for you to explore the commands – feel free to play around beyond what is described here.
Once you gain familiarity, you can learn more of Stata’s operations using Stata’s help and search functions, trying
on-line tutorials, or searching through Stata’s list serve available at http://www.stata.com/statalist/archive. It will
be easier to follow the whole document in the sequence, but you may skip and try only the sections that interest you.
If you have any questions about or suggestions for this guide, please email [email protected].
Table of Contents
1.
INTRODUCTION .......................................................................................................................................................... 3
1.1.
1.2.
1.3.
2.
GETTING HELP IN STATA ........................................................................................................................................... 4
INTERPRETING STATA’S HELP PAGES ........................................................................................................................ 4
ABOUT DATA FOR STATA .......................................................................................................................................... 5
READ IN DATA............................................................................................................................................................. 6
2.1.
2.2.
2.3.
2.4.
3.
READING IN AN ASCII DATA FILE WITH A STATA SET UP FILE................................................................................... 6
CREATING A STATA SET UP FILE................................................................................................................................ 8
READING IN AN EXCEL FILE ...................................................................................................................................... 9
READING IN STATA DATA ........................................................................................................................................ 11
DATA MANAGEMENT.............................................................................................................................................. 13
3.1.
3.2.
3.3.
3.4.
3.5.
APPEND ................................................................................................................................................................... 13
MERGE .................................................................................................................................................................... 13
TRANSPOSE ............................................................................................................................................................. 14
RESHAPE ................................................................................................................................................................. 14
ORGANIZING VARIABLES ......................................................................................................................................... 15
4.
EXPLORE DATA ........................................................................................................................................................ 16
5.
OBTAIN DESCRIPTIVE STATISTICS.................................................................................................................... 19
6.
TRANSFORM VARIABLES AND RECORDS ........................................................................................................ 20
7.
GRAPH ......................................................................................................................................................................... 22
8.
OBTAIN DIFFERENCE OF MEANS STATISTICS ............................................................................................... 23
9.
OBTAIN LINEAR REGRESSION ESTIMATES .................................................................................................... 24
10.
DO FILES ................................................................................................................................................................. 25
11.
SHORTCUT MENUS .............................................................................................................................................. 25
12.
EXPORTING RESULTS......................................................................................................................................... 26
13.
OTHER HELPFUL COMMANDS ........................................................................................................................ 27
14.
ON-LINE TUTORIALS .......................................................................................................................................... 28
15.
REFERENCES ......................................................................................................................................................... 28
* The period (.) in front of Stata commands indicates Stata prompt. Do not type the period as a part of the command.
* Stata commands are separated by “–“ in texts, as in –help-.
* The words to be replaced are written in italics.
* The variable names are in capital letters (unless they are in the command lines). Stata is case sensitive (upper case and lower
case are seen as different characters).
Page 2 of 28
1. Introduction
Stata is a statistical analysis package, used for manipulating, examining, summarizing, and graphing data. Stata contains
statistical commands that are built into the program and allows the users to do statistical analyses such as cross-tabulations and
regression analyses. Stata stores data in its own format. Once a data set is in its memory, Stata will output the results
responding to your commands. Commands can be executed one at a time interactively, or in groups in a command file.
Princeton University has Unix version of Stata on the server tombstone, and Windows and Macintosh versions on the Office of
Information Technology (OIT) cluster computers. If you have Princeton computer accounts, you have access to either version.
To use the Unix version, your tombstone account has to be activated. For more information about activating your account,
check OIT’s help sites on the web (see http://helpdesk.princeton.edu/kb/display.plx?id=9682). In this guide, you will learn
how to submit individual commands using a Windows version of Stata.
A Windows version of Stata shows four windows as in the picture below*. The rectangular window on the bottom is the
Command window, where you enter your commands. The largest dark window is the Results window. The commands you
enter in the Command window and Stata’s response to the commands appear in the Results window. The window on the top
left corner, the Review window, is where Stata puts the commands you had submitted. If you want to reuse the command, you
can click on the command shown in the Review window to input it in the Command window. The Variable window, shown
below the Review window in the picture, shows a list of the variables in the data set in the memory. You may click on the
variable names in the Variables window to input them into your commands in the Command window. You can resize the
windows by dragging the borders. If you widen the Variables window, you can also see the variable labels (if the labels exist in
your data).
You can also submit commands using the menus on the top bar. In this guide, I will show doing the same thing using either
commands or menus, where applicable. In the texts, where it says CMD is where you enter commands in the Command
window, and where it says MNU is where you click menus from the menu bar.
* The position of the windows may not be exactly the same as in this picture.
Page 3 of 28
1.1. Getting help in Stata
If you are not sure what the command is, you can search for
the command in Stata using the search function.
CMD: Search commands by typing –search- and a keyword in
the command window. Stata will display a list of commands
and other resources associated with that keyword, if there are
any. For example, type in the Command window,
. search regression
MNU: Alternatively, you can click Help => Search from the
menu on the top, and input keywords in the dialog box. Click
on the name of one of the commands or resources to display
the help screen.
If you know what the command is and want to know the
detail about the command, use Stata’s help function.
CMD: Type –help- and a command name.
. help regress
MNU: You may click Help => Stata command, then input command name in the dialog box. Stata will then display a help
window.
1.2. Interpreting Stata’s Help Pages
Help page shows the command you just typed, -help
regress- in this example, on the top. Next to it are blue
letters next to “dialogs:” and “also see:”. Any of the blue
letters in help windows are clickable. The commands next
to “dialogs:” open the dialog box associated with the
command, and the commands next to “also see:” open
help pages that are related with the command. Title,
which the help is about, shows a letter in brackets. In
addition to the on-line help, Stata has print manuals. The
letter in the brackets indicates the volume of the printed
manual, R, that contains the information on regress.
Syntax is Stata’s command language structure. Underlined
letters are the minimum number of characters Stata
recognizes as the command. So, if you type reg in the
command window, Stata understands it as regress. After
the word regress, Stata expects depvar, a dependent
variable. The depvar is required. indepvars, if, in,
weight, ,options, are all in brackets. The bracketted words
are optional, and the command works without them.
What goes in to the ,options are explained underneath.
Description describes what the command is for. More
details of the options follow. If you scroll further down,
there are examples. Examples are helpful in seeing how to
type the commands. Often times, examples contain series
of commands you can try out with Stata’s example data set,
which comes with the installation.
Page 4 of 28
1.3. About Data for Stata
To put a data set into Stata’s memory, the data set has to be in a format Stata understands. The following is a list of the
extensions of files Stata can read directly.
Data Format
File Extension
Stata
.dta
Text (ASCII)
Free or fixed columns
.raw, .txt
Comma separated values
.csv
Fixed columns
.dat
SAS export
.xport, xpt
MS Access
.mdb
Command to read the data
. use
. infile using
. insheet using
. infix using
. fdause
. odbc
Many data download sites provide you with data already formatted for a common statistical program such as Stata, SPSS, or
SAS. Formatted data often contain variable labels and value labels, that make it easier for you to understand the contents of the
data.
If Stata data are not available, and you can choose a data format between SPSS and SAS, then I would recommend selecting
SPSS. You can use SPSS to open SPSS data, then save the data as Stata data. SPSS versions 12 and up can save the data as
Stata 8 data 1 . Windows version of SPSS is available in McCosh 59 cluster or DSS computer lab. If data are only available in
SAS format, you may use SAS to open SAS data, then create SAS export file, as Stata can read a SAS export file. Windows
version of SAS is available in DSS computer lab. Unix version of SPSS and SAS are available at tombstone.
Also, if you acquire data that are in a format other than Stata, you may use DBMS/Copy to convert them into Stata format.
Windows version of DBMS/Copy is available in DSS computer lab. Unix version of DBMS/Copy is available at Tombstone.
If you have SAS data, we recommend converting them into SAS transport file in SAS instead of using DBMS/Copy.
DBMS/Copy has a known issue in converting value labels from SAS to Stata.
If formatted data are not available, data distributers may provide set up files in Stata, SPSS, or SAS along with ASCII data.
ASCII data set is a text file with rows (or columns) of numbers. If a set up file is available in Stata, you can attach the variable
information using Stata. If a set up file is available in SPSS, it will be easier to use SPSS to attach the definition, then save the
data as Stata data. If a set up file is available in SAS, you may use SAS to attach the file definition, then create a SAS export file
in SAS. You may also modify the set up files in text editors to use in Stata. Commands to define data are different in all three
programs. If no set up files are available and only PDF codebooks are available, you will need to select the variables you want
to use and create your own set up file for Stata.
If you need help in defining or converting data, please come by the Data and Statistical Services computer lab at A-16-H-3 in
Firestone Library during walk-in hours or email [email protected]. The hours and directions are available at
http://dss.princeton.edu. If you are emailing questions, please use your Princeton email. Our resources and assistance are
available to Princeton University community members.
Stata data format has changed from version 9 to version 10. Stata 10 can read data saved for Stata 9, but Stata 9 can not read
data saved for Stata 10, while both has the same extension .dta. If you plan to use Stata 9 after using Stata 10, you may save the
data as Stata 9 data in Stata 10. Followinig commands allow you to save data as Stata 9 data in Stata 10.
CMD: . saveold filename
MNU: File=> Save As. Then select “Stata 9 Data” from the drop down list for box “Save As Type:”
1
Stata 8 and Stata 9 data are interchangeable.
Page 5 of 28
2. Read in data
2.1. Reading in an ASCII data file using a Stata set up file.
Often times, you may obtain a command and a dictionary files as a set of Stata set up files along with a data file. I suggest that
you save all three files in the same directory. The command file has an extension .do, the dictionary file .dct and data file .txt
(or .dat). The command files in Stata are also called do files. Sometimes the do file contains the dictionary, and you have two
files, do file and data file. The procedure is similar to having three files.
As an example, I downloaded a Stata set up file and data file for National Health Interview Survey from the Inter-university
Consortium for Political and Social Research (ICPSR) web site, http://www.icpsr.umich.edu. The files usually are zipped when
you download. I extracted the zipped files using WinZip, and put them in C:\StataHandsOn\SampleData directory. WinZip is
available in DSS lab computers. OIT computers do not have WinZip, but extraction software that comes with Windows can
unzip files.
Then I opened the Stata command file using NotePad (any text editor will do, but not a word processor like MS Word).
Instructions are given at the beginning of the command file, sandwiched between lines of asterisks as in the picture below. A
forward slash and an asterisc (/* texts */) makes the texts in between comments. Follow the instruction and specify the name
and the path of the data, dictionary, and output data files in the do file. Here is a copy of the beginning of the do file for the
National Health Interview Survey data.
Page 6 of 28
/**************************************************************************
|
STATA SETUP FILE FOR ICPSR 04349
|
NATIONAL HEALTH INTERVIEW SURVEY, 2004
|
(DATASET 0004: SAMPLE ADULT)
|
| Please edit this file as instructed below.
| To execute, start Stata, change to the directory containing:
|
- this do file
|
- the ASCII data file
|
- the dictionary file
|
| Then execute the do file (e.g., do 04349-0004-statasetup.do)
**************************************************************************/
set mem 40m /* Allocating 40 megabyte(s) of RAM for Stata SE to read the
data file into memory. */
set more off /* This prevents the Stata output viewer from pausing the
process*/
/****************************************************
Section 1: File Specifications
This section assigns local macros to the necessary files.
Please edit:
"data-filename" ==> The name of data file downloaded from ICPSR
"dictionary-filename" ==> The name of the dictionary file downloaded.
"stata-datafile" ==> The name you wish to call your Stata data file.
Note: We assume that the raw data, dictionary, and setup (this do file) all
reside in the same directory (or folder). If that is not the case
you will need to include paths as well as filenames in the macros.
********************************************************/
File Path
File Name
Replace the
file names
here.
local raw_data "C:\StataHandsOn\SampleData\04349-0004-Data.txt"
local dict "C:\StataHandsOn\SampleData\04349-0004-Stata_dictionary.dct"
local outfile "C:\StataHandsOn\SampleData\health.dta"
/********************************************************
Section 2: Infile Command
This section reads the raw data into Stata format. If Section 1 was defined
properly, there should be no reason to modify this section. These macros
should inflate automatically.
**********************************************************/
infile using `dict', using (`raw_data') clear
Once you have the file paths and names inserted into the do file, execute the do file (in this example named 04349-0004Setup.do) in Stata by giving a command:
. do 04349-0004-Setup
In this case, you do not need to modify the dictionary file. In some cases, you may need to specify the data file path and name
in the dictionary file.
I specified in the do file to name output Stata data as health.dta (see the third line that starts with “local outfile”), and you see
the file listed in the directory in the picture on the previous page.
You may obtain a data definition file for SAS or SPSS. The idea of attaching the data definition in SAS or in SPSS is the same
as in Stata, except that their data definition would only be in one file, and they need to be executed in respective program.
Please refer to separate handouts for details in running data definition files using SAS or SPSS.
Page 7 of 28
2.2. Creating a Stata set up file.
When you have an ASCII data file but not a set up file, you will need to create one to define variables. An ASCII data file
contains many rows of numbers and Stata will not know which numbers belong to which variables. You also need to define the
type of variables, whether they are numeric (numbers) or string (texts or characters). ASCII data may be in free format, comma
separated, or fixed columns. Example files used in this exercise are 2008 Democratic and Republican Presidential
Primaries/Iraq (United States), downloaded from the Roper Center, http://www.ropercenter.uconn.edu.
Here is a portion of a fixed column ASCII data, called lat544.dat:
.25
1.66
.47
.41
1
2
3
4
2391 1 1 1 4 2 1 2 3 3 2 & 338 & & & & & & & 131 5 6 7 7 3 1 4 4 4 4 4 4 & & & & 0 & & & 2 0 2 2 1 2 2 0 1 2 1 1 2 2 2 1 4 2 & 5 1 2 3 2 65 & 6 112 5 1 2
9041 1 1 1 4 1 2 1 2 3 2 & 8 13& & & & & & & 5 2 1 3 3 6 3 1 4 & & & & & 4 4 4 4 4 3 5 & 1 2 1 2 4 2 2 0 1 2 1 4 1 1 1 1 5 2 & 1 3 4 1 1 55 & 6 6 1 5 1 2
2122 4 4 4 2 3 2 4 2 1 1 & 1 2 112 5 3 6 6 6 & & & & & & & & 1 & & & & & 1 1 1 1 0 & & & 2 2 2 1 1 1 1 4 2 1 2 1 2 1 1 1 1 1 & 1 7 & & & 65 & 7 8 1 2 1 1
4122 4 4 4 1 2 4 1 1 1 1 & 1 8 7 2 3 1 2 5 6 & & & & & & & & 1 & & & & & 1 1 1 1 0 & & & 3 3 3 3 1 1 1 4 0 1 2 0 2 1 2 1 2 1 & 1 2 3 1 1 & 5 5 5 2 2 1 1
A portion of the corresponding codebook says ...
Data Locations
Variable Rec Start
WTVAR
1
1
CASE
1
8
AREACODE 1
15
TRACK
1
22
GWBUSHJO 1
24
GWBECON
1
26
GWBIRAQ 28 29 A2
End Format
7
F7.2
14
F7.0
21
F7.0
23
A2
25
A2
27
A2
This means that the variable WTVAR is at the first record, starts
from the column 1 and ends in column 7. The data format is F7.2,
meaning that it’s a numeric variable with width 7, and includes two
decimal places. In the data above, .25, 1.66, .47, and .41 correspond
to this variable.
To define the variables in Stata, you can create a “dictionary” file that
contains the variable information as in below. You can use any text
editors, but here we use Stata’s “do-file editor.” Open a do-flie editor:
CMD: . doedit
MNU: Window-> Do File Editor -> New Do File.
infix dictionary using H:\lat544.dat {
WTVAR 1-7
CASE 8-14
AREACODE 15-21
str TRACK 22-23
str GWBUSHJO 24-25
str GWBECON 26-27
str GWBIRAQ 28-29
}
There, type
Carriage return is Stata’s default signal to end
commands. So it is important to type as it appears
here. The first line ends after the squiggly-brace
({ ), each variable name and the column locations
is in one line, and the last squiggly-brace ( }) is on
its own line.
and save the file as a dictionary (.dct) file in the same directory as the data file. For example, I saved the file as H:\ lat544.dct, as
I have the data file, lat544.dat, at the root of H drive. The str in front of variable names indicates that they are string variables.
I have omitted record number, as there is only one record in this data. If your data file has more than one record, you need to
define which record you are referring to for each of the variables. Please see help infix to see the syntax for multiple records.
Once you save the dictionary file,
CMD: . infix using H:\lat544.dct
MNU: File => Import => ASCII data in fixed format. Then Browse to find the dictionary file name and path.
Stata will show the following in the output window.
. infix dictionary using H:\lat544.dat {
WTVAR 1-7
CASE 8-14
AREACODE 15-21
str TRACK 22-23
str GWBUSHJO 24-25
str GWBECON 26-27
str GWBIRAQ 28-29
}
(1373 observations read)
Check with the codebook and see if the total number of records is 1373.
Page 8 of 28
2.3. Reading in an Excel file
If the data file is “clean,” all you need to do is to save the file as .csv file in Excel and import it into Stata. However, if the data
file is “not clean,” editing it may make it easy to import it into Stata. Here is an example of a “not clean” excel file.
header lines
variable names include special
characters, starts with a number,
or have spaces between words
Stata reads the values in the first line
as the variable names. Header lines
prevent the program to read the
variable names. Also, the program
expects data from the second line, so
in this example, Stata will convert all
the variables as string.
The variable names in Stata can not
have special symbols or start with an
underscore (_).
each value includes a
special character and
a comma
The following is an example of a
“clean” excel sheet. It has the
following characteristics:
blank line
and column
the second line.
•
No blank rows or columns. (Blank
cells are ok. Stata automatically adds a
period (.) if numeric. Do not manually
add . in blank cells.)
•
Missing numeric data should be an
empty cell or values defined as missing,
such as 0, 9, or 99. A space (stored
space, different from empty), dot, or
any other non-numeric character such
as n/a will cause the variable to
become string.
•
Commas in numbers or texts are
particularly problematic because Stata
may see them as a delimiter and will
not read the data properly. You
should remove the commas from
numeric values before saving the file.
•
The first line has Stata
variable names: 32
characters or less, no special
characters, and not starting
with an underscore or
number. Data begin from
Page 9 of 28
Once you examine the file and make sure that the file is clean, here is a step-by-step instruction for saving a worksheet as a
comma separated values file in Excel. As a practice, let’s read in a sample excel data.
1.
2.
3.
4.
5.
6.
Open the Internet Explorer and download
auto.xls from
https://webshare.princeton.edu/users/furuic
hi/auto.xls and select Save to Disk.
Save the file in your H:\ directory.
Start Excel and read the file by selecting File
=> Open
Under the File menu, select Save As, then
Save as type 'CSV' (comma separated values).
Open Stata
Change the directory in Stata
Note: Renaming the file with a .csv extension in the
Windows Explorer is not the same as saving the file as
a .csv file.
If the spreadsheet is small, you may copy the data and paste them into
Stata’s data editor. Highlight all data in Excel, and select Edit =>
Copy. Open Stata, then select Data Editor. Right click and select
Paste, or press Control and v keys at the same time to paste the Excel
data contents into Stata’s Data editor.
Stata may mistakenly read numeric variables as strings. Check that
original numeric values are numeric in converted Stata data by issuing
the command –describe- in Stata and examining the storage type. If the
variable has storage type that starts with "str," then Stata has made it a string variable.
If you see that a numeric variable in the original data file has
string storage type in Stata, go back to Excel, and change the
variable’s format into numeric, and re-save the file as .csv file.
Here is how:
1.
2.
3.
4.
5.
6.
Highlight the column with the numeric variable name.
Click Format => Cells.
In the Format Cells window, select Number tab.
Under Category drop down list, select Number.
Click OK
Under the File menu, select Save As, then Save as
type 'CSV' (comma separated values).
You can also change the variable type from string to numeric
in Stata. At the command prompt, type
. destring stringvariablename, replace
For this command to work, the stringvariablename can not have any non-numeric characters as its value. If it fails, check the
values of the variable to find non-numeric characters.
Page 10 of 28
2.4. Reading in Stata data
Now, let’s start using Stata. From an OIT computer, a link to Stata may be found in Start => All Programs => Stata10 =>
StataSE10. A shortcut to Stata may be available from the Special Applications folder on the desktop. Double click the Stata
icon.
Typing commands in the Command window
Stata starts in its default working folder, typically C:\Program
Files\Stata\Stata10. Let’s change the directory to
H:\StataHandsOn.
. cd H:\
Let’s create a StataHandsOn directory.
. mkdir StataHandsOn
. cd StataHandsOn
Before reading in a data file, let’s open a log file. A log file stores
your output that appears in the Results Window.
. log using auto1.log
Now let’s read in 1978 Auto data. It is a data file that comes with
Stata installation, and available in Stata format.
. sysuse auto
Suppose you want to add a label to the data, so that you can
remember what the dataset is about. It is convenient if you make
many subsets of data files from the original file. As an exercise, let’s
label the data that it is for 1978 auto data for hands on training.
. label data “1978 auto data for hands on training”
We will work more on this data, but let’s save the data at this time.
We’ll give it a name, testauto.
. save testauto
Let’s close a log file at this time and look at the file. Issue a
command:
. log close
using Menus
File =>
Change
Working
Directory..
(navigate to
H:) then
select Make
New Folder
File => Log
=> Begin....
File=>
Example
datasets =>
Example
datasets
installed with
Stata =>
(auto.dta) use
Data=>
Labels=>
Label dataset
Notes and Tips
If you don't change the directory, Stata will assume
that the file name you type is in the default
directory. The log and data files you save will also
be in this directory unless you change it.
If you do not open a log file at the beginning of the
session, the output will only be available in the
temporary memory. Once you exit from the
program, the output will be lost.
A log file with the extension ".log" is a plain text file.
This means you can open and read it in almost any
text editor or word processor. If you issued the –
log- command without the file extension,
. log using stata1
Stata would create "stata1.smcl." smcl is a log file
type specific for Stata.
Notice that “log on (text)” appear on the rectangular
space between Results Window and Command
Window once you begin a log.
If you issue –save, replace- command without
specifying a file name, what is currently in memory
will overwrite original input file. To avoid losing
original data file by mistake, always remember to
make a master copy before starting to work on
data.
File=> Save
as
File=> Log=>
Close
Notice that “log on (text)” disappeared from the
rectangular space after closing the log.
Use a text editor or MS Word to open the log file.
You can also view a log file in Stata. Remember to include the
extension with the file name when typing the –view- command.
. view stata1.log
Let’s clear the data in the memory at this time and exit from Stata.
. clear
. exit
File=> Log=>
View
File=> Exit
Results window can not be cleared while in
session.
using Menus
Page 11 of 28
Typing commands in the Command window
Restart Stata, and check if we are in the directory we first specified.
. pwd
then list the files:
. ls
Notes and Tips
File=>
Change
working
directory...
It should show that we are at H:\StataHandsOn directory. Can you
find the testauto.dta and auto1.log? What is the size of the data file?
. log using stata1.log, append
To read testauto data:
. use testauto
If the data file is larger than Stata’s current memory, it will issue an
error message. Check the file size and set memory to give Stata
more space. For example, if the data file is 36 megabytes, type
. set memory 40m
It gives 40 megabytes worth of data memory in Stata to read the
data.
You can see the directory Stata is pointing at by
looking at the bottom bar of Stata’s window. If you
are not at H:\StataHandsOn, change the directoyr
by typing in the Command window:
. cd H:\StataHandsOn
It is a small data file, of only 5.4 kilobytes. As you may have seen
at the very first screen, Stata’s memory may be initially set to 10
megabytes. Because this data file is smaller than what Stata allows
in the memory at this time, you will not have problems reading in
the data.
Let’s open the log file back on to continue to save the output on the
same log file. Issue a command:
pwd stands for Present Working Directory.
File=> Log=>
Begin, then
select
stata1.log,
and Append
to existing file
File=> Open
(no equivalent
menu)
You can, of course, start a new log file instead of
appending the new results to the existing log file.
To start a new log file, give a new file name as in:
. log using stata2.log
You could clear the data in memory and read in a
new data file in one step, by issuing a command:
. use testauto, clear
Only one data file can be read into the Stata’s
memory at a time. You need to clear the memory
before reading in another set of data. (You can,
however, open many instances of Stata in one
computer.)
To see the maximum limits in Stata, type in the
Command window:
. help limits
Review Questions:
1. How can I start Stata?
2. Which directory is this program pointing at?
3. How can I change the directory to H:\?
4. How large is the Auto data?
5. How do I read the data into Stata?
6. How do I label the data?
7. How do I save the data?
8. I don’t know what commands to use. How do I get a help
in Stata?
9. How do I record the output?
Hints:
. pwd
. cd C:\mydata
. dir . ls
. set memory 20m
. use filename
. label data “descriptions”
. save filename, replace
. help commandname
. search keyword
Page 12 of 28
3. Data management
Goal: combine, transpose, and reshape data files. Search, order, and rename variables.
You may have multiple files you want to combine. Some files are so large that they are split into multiple files, having the same
variables but different cases, for downloading. If you want to combine datasets that have same variables but different cases, the
command you use is –append-. Some longitudinal studies follow up same individuals across time and ask same or different
questions. If you want to combine datasets that have same cases or people but have different variables, the command you use is
–merge-.
3.1. Append
Let’s create sample data first, then we will try appending.
. sysuse auto
. keep make price mpg
. keep in 1/5
. save temp
. keep in 4/5
. save data1
data1 will look like:
3.2. Merge
This time, we will try merging. We will do match merge,
meaning we want to merge two files matched by the key
variable, in this case MAKE. Because we are adding a
variable, we want to make sure that the variable values are
assigned to the right observations. For match merge, it’s
very important that BOTH files are sorted by the key
variable.
. use temp
. keep make price
. sort make
/* IMPORTANT! */
. save data2
data2 will look like:
. use temp, clear
. keep in 1/3
. use temp, clear
. keep make mpg
. sort make
/* IMPORTANT! */
Let’s combine the two dataset. What I want to do is to
stack data1 under the second dataset. While having the
second data still in memory,
. append using data1
Resulting dataset looks like:
. merge using data2
Page 13 of 28
3.4. Reshape
Reshaping dataset is useful when you have, for example,
time series data and have the same question asked across
time as separate variables.
Notice there is a new variable called _merge. Stata
automatically creates this variable whenever files are
merged. _merge can have values 1, 2, or 3. 1 means that
the records are in data in memory before merging, but not
in data2. 2 means that the records are in data2 but not in
the data that were in memory at the time of the merge. 3
means that the records were in both files. In this example,
all records matched up in two files.
3.3. Transpose
Transposing is switching observations and variables. In
Stata, string values can not be transposed except for
variable names. If you have string values, you will need to
encode them and make them numeric before transposing.
The command to transpose is –xpose-.
This time, we will use another Stata’s example file. To use
this file, your computer needs to be connected to internet.
Here again, we will use Stata’s example file. Your
computer needs to be connected to internet to use this file.
. webuse reshape1
. drop ue*
I dropped ue variables to save space. If you keep them,
you need to include ue in the reshape command after inc.
In this file, you see three persons’ incomes for 1980, 1981,
and 1982. Suppose you want to have a variable called year,
and have the income values listed for each year for each
person. Then what you want to do is to reshape it into a
long format.
. reshape long inc, i(id) j(year)
Here, the command is telling Stata that inc is a stem of the
variable whose values need to be repeated for a person for
different years, by id. The variable year does not exist in
the pre-reshaped data, but will be assigned as the variable
name for the values attached to inc that will become a
variable. It may be easier to understand this by comparing
post-reshaped data with pre-reshaped data.
Now you see that there is a new variable called year, and
the id and sex is repeated for different years.
varname is an option, but clear is required in xpose
command. With the option varname, the transposed
dataset will contain the variable names as a variable.
To go from the long format to wide format (in the format
of post-reshaped file to pre-reshaped file in the above
example), the command is –reshape wide. reshape wide inc, i(id) j(year)
Page 14 of 28
3.5. Organizing variables
Typing commands in the Command window
If you have a large data file with many variables, it may be difficult
to find variables by using –describe- or –codebook-. Here are some
commands that may be helpful if you have a large data file. The
command –lookfor- search for a variable that has either name or
label that contains the keyword. Let’s use another example data to
try the commands.
. sysuse nlsw88
Let’s see if there are variables that contain the word married, age,
and education.
. lookfor married
. lookfor age
. lookfor education
You can order the variables alphabetically by the variable names.
. aorder
If you want to place a variable at a particular location, -order- var1
var2 places var1 before var2. For example,
. order smsa age
places smsa before age, after idcode.
If you want to rename variables, the command is –rename-.
. rename idcode id
using Menus
File=> Example
datasets...=>
Example
datasets
installed with
Stata, click use
next to
nlsw88.dta
(no equivalent in
menu)
Data=> Variable
utilities=>
Alphabetize
variables
Data=> Variable
utilities=>
Change order of
variables in
dataset
Data=> Variable
utilities=>
Rename
variable
Notes and Tips
If Stata returns blank, it means there is no
variable that contains the word. In this
example, it does not mean there is no
education variables. You can see that there
are variables called grade and collgrad, as it is
a small dataset. It did not find those variables
because the keyword education was not a part
of the variable name or label. So, -lookforhelps you find the variable if you know what to
look for. You would still need to read the
codebook to know the appropriate keywords
you can use to search for variables.
If you have many variables with the same
stem, such as education1, education2, ..., you
can rename the stem education to edu by
using the command renpfix
. renpfix education edu
renames the variable idcode to new name, id.
This command will rename education1,
education2, ... to edu1, edu2, ....
Review Questions:
1. How do you search for a variable in a dataset?
2. How do you order variables in an alphabetical order?
3. How can I move a variable next to another one?
4. How can I rename variables?
Hints:
. lookfor
. aorder
. order
. rename
4. Explore data
Goal: find out what information is in the data – how many variables are in the data, what variables are in
the data, and what they mean.
Typing commands in the Command window
Now let’s see what this data file contains.
. describe
The -describe- command shows you the path, label, date, and the
size of the data file, the number of observations and variables, and
the name, type, format, and label of the variables in the dataset.
You will also notice that it says “_dta has notes.” Let’s see what the
notes say.
. notes
You can also add your own notes to the data.
. note: I used this data set in a hands-on training course during the
fall of 2008.
See it by typing –notes-.
We also see that the variable FOREIGN has a label called origin.
You can see the details about the label by typing:
. labelbook origin
Suppose we want to know what the REP78 is about. The
–codebook- command gives you detail of the variable. Type:
. codebook rep78
If you want to get a quick summary of numeric variables, -inspectreports the number of negative, zero, and positive values; the
number of integers and non-integers; the number of unique values;
and the number of missing; and it produces a small histogram. Try:
. inspect mpg
The –list- command lists values of the different variables in your
dataset on the Results window. Similarly, -browse- open the data
browser. You can have browser open only for the variables you
want to see. For example,
. list make
. browse make
In using –list-, you may see –more- on the bottom of the screen.
To scroll down the screens, hit space bar or click –more-.
If you only want to see first five observations of the variable
MAKE, type
. list make in 1/5
. browse make in 1/5
using Menus
Notes and Tips
Data=>
Describe data=>
Describe data in
memory
There are two types of variables: numeric and
string. Numeric variables are numbers. String
variables contain texts which can contain any
characters on the keyboard: letters, numbers,
and special characters.
Data=> Notes=>
List notes
Data=> Notes=>
Add notes
Data=> Notes=>
List notes
Data=>
Labels=> Label
values=>
Produce
codebook of
value labels
The storage type refers to the size used in
storing the variables. Numeric variables’
storage types include byte, int, long, float, and
double. String variables have storage types
that begin with "str", followed by a number
indicating the maximum length of the string:
e.g., str18.
We can do numeric calculations and statistical
analysis on numeric variables, but not on
string variables. A variable that looks like a
number, for example, “20025” could be either
a string (a set of five characters that happen to
be numbers, like a zip code) or a numeric
value (the integer that’s after 20024). It's
important to check the variable types to know
how you can analyze those variables.
Data=>
Describe data=>
Describe data
contents
(codebook)
Data=>
Describe data=>
Inspect
variables
Data=>
Describe data=>
List data
You can also click on Data Browser to see the
data file. While you have the browser open,
you can not enter commands. Closing the
browser does not delete the data file.
Data=> Data
Browser
click by/if/in tab
in list dialog box,
and select Use a
range of
observations
Page 16 of 28
Typing commands in the Command window
The –list- command is particularly helpful to use after sorting data,
or combining with if. For example, you can obtain five minimum
values of MPG by listing the first five records after sorting.
. sort mpg
. list mpg in 1/5
Suppose you want to see the make of the cars whose price is less
than $5000. Try:
. list make price if price<5000
The –if- qualifier
using Menus
Data=> Sort=>
Ascending sort
Data=>
Describe data=>
List data
click by/if/in tab
in list dialog box,
and select
Create, type in
price<5000
The –if- qualifier is used to isolate a set of observations with
variables meeting some particular criteria. Values on variables in a
dataset are compared to values on other variables or to numbers or
strings using logical comparison operators.
Operator
==
>
>=
<
<=
!= or ~=
Notes and Tips
To list last five records (maximum values):
. list mpg in -5/-1
To sort in reverse order, use –gsort-.
. gsort –mpg sorts MPG in reverse.
. gsort +mpg is the same as . sort mpg.
Pay special attention to that double equals
sign! If you are evaluating for equality, use a
double equals sign (==). A single equals sign
(=) is used for assignments, to set something
equal to something else.
For example, if you want to list all information
in the dataset about cars whose MAKE is
“subaru”, you would type:
. list if make=="subaru"
Meaning
equal to
greater than
greater than or equal to
less than
less than or equal to
not equal to
String values need to be put in quotes.
Whereas if you want to create a new variable
called POWERSTEER for cars whose make is
SUBARU, you would type:
. generate powersteer=1 if make==“subaru”
Refer to the section on “Transform variables
and records” for more information on creating
new variables.
You can put spaces around these operators (e.g., either a >= b or
a>=b), but you cannot put spaces within them (e.g., it must be
‘>=’, not ‘> =’).
Combining tests: -and- and –or-
Note that the –if- statement is included only
once.
-if- can be combined with and (&) to evaluate for more than one
conditions. Let's say you want to find out the MAKE of the cars
whose MPG is greater than 30 and PRICE is less than $5000.
. list make if mpg>=30 & mpg<=40
(OK)
. list make if mpg>=30 & if mpg<=40 (won’t
work)
. list make if mpg>30 & price<5000
. list make if 30<= mpg <=40 (won’t work)
-if- can also be combined with or (|) to look at cases where at least
one of two or more conditions is met. For example:
“|” can be obtained by pressing shift and \..
The \ key is between Backspace and Enter
keys on most key boards.
. list make if mpg>30 | price<5000
It is possible to combine the & and | operators. If you have both
in one command, & takes precedence over |. Use parentheses to
help you organize them and avoid errors, as combining & and | can
make the conditions complicated.
Among missing values, after a period, the
values increase by a combination of a period
and an alphabet character. So, .a is larger
than ., .b is larger than .a: .z is the largest
missing value.
. list make if (30<= mpg | 2000<price ) & rep78<4
returns different results from:
. list make if 30<=mpg | 2000<price & rep78<4
using Menus
Page 17 of 28
Typing commands in the Command window
Notes and Tips
About Missing Values
Stata indicates a missing numerical value as a period (.), and a
missing string value an empty string, “”. Missing numerical values
are larger than numerical numbers.
We know from the previous examination (.codebook rep78) that
five out of 74 records of REP78 are missing. We can use the period
to indicate missing record in the command and see which MAKE
of the cars are missing in the data.
. list make if rep78 >= .
Check that a period is the largest values in rep78, by sorting by
rep78 and listing the last six values.
Data=>
Describe data=>
List data
click by/if/in tab
in list dialog box
Data=> Sort=>
Ascending sort
. sort rep78
. list make rep78 in -6/-1
Review Questions:
5. How many variables and records are in the data?
6. What does the note say?
7. How can I add notes or comments to the data?
8. What variables are in the data?
9. How do I sort?
10. Which variables have missing values?
11. List the cars for which data is missing.
12. List the cars whose repair record is less than 3 and the
price is less than $5,000
Hints:
. describe
. codebook . labelbook
. inspect
. summarize
. sort
. gsort
. list [if] [in]
Page 18 of 28
5. Obtain descriptive statistics
Goal: find out number of missing records, minimum and maximum values, means, and medians, view
frequency tables, and cross tabulations.
The commands that are useful for getting basic descriptive statistics include tabulate, summarize, tabstat, and table.
Typing commands in the Command window
using Menus
The –tabulate- command gives you a frequency distribution
if only one variable is specified, and a cross-tabulation if two
variables are specified. If two variables are specified, the first
variable will be shown in rows, and the second in columns.
Statistics=>
Summaries,
tables, and
tests=>
Tables=> Oneway tables, or All
possible twoway tabulations
. tabulate rep78
. tabulate rep78 foreign
-summarize- gives the number of valid observations, mean,
standard deviation, minimum, and maximum values.
. summarize price mpg
What if you wanted to see the average MPG for foreign and
domestic cars? The –tabulate- command can be combined
with –summarize- to produce a summary of one variable for
the variable specified in –tabulate-. For example, if you want
to see the average MPG by car type, type:
. tabulate foreign, sum(mpg)
If you want to see more statistics such as total, range, or
median, you may use tabstat.
. tabstat price mpg, stat(sum, range, median)
There are more statistics you can see using tabstat. See . help
tabstat for a list of statistis.
Statistics=>
Summaries,
tables, and
tests=>Summary
and descriptive
statistics=>
Summary
statistics
Statistics=>
Summaries,
tables, and
tests=>
Tables=>
One/two way
table of
summary
statistics
Notes and Tips
–tabulate- can not cross-tabulate more than two
variables. If you have more than two categorical
variables to crosstab, use –table- (see below).
Because –tabulate- gives you frequency counts, it
makes sense to use it for categorical variables than
continuous variables.
It would make sense to summarize continuous
variables rather than categorical variables.
You can also see the average MPG by FOREIGN
by using –by- and –summarize-.
. bysort foreign, summarize(mpg)
To use –by-, the data have to be sorted by
FOREIGN. You could do .sort foreign, then .by
foreign, sum(mpg). . bysort foreign does the
sorting and by in one step.
Stata allows shorthand in some commands. –sumis the shorthand for –summary-. The shorthand is
shown as an underscored letters in the help page.
The –table- command lets you create three-way (or four-way
if combined with –by-) cross-tabulations. We can try that
after we create more categorical variables in the next section.
Review Questions:
1. Which five cars yield the lowest gas mileage?
Which five cars yield the highest gas mileage?
2. What is the average price and average miles per
gallon (MPG) of a car in the 1978 auto data?
3. What is the average price of cars that are below and
above the mean MPG?
4. What is the median MPG?
5. How are price and MPG different for domestic and
foreign cars?
6. How can I see the number of cars by the car type?
7. How are the cars distributed by the repair records?
8. Compare frequency-of-repair records for domestic
and foreign cars.
Hints:
. sort
. list
. summarize
. tabulate
. table
. by groupingvarname: summarize varnames
Page 19 of 28
6. Transform variables and records
Goal: create and label new variables, modify existing variables, keep or delete variables and records from the file,
recode values, create dummy variables from existing variables.
The basic commands for creating new variables and modifying old ones are –generate- and –replace-.
Typing commands in the Command window
The command
. generate newvar = something
creates a new variable named newvar and sets it equal to
something. Something can be a number, a string, a mathematical
expression, or a function of other variables. You can combine
–if-, -&-, and -|- in generating new variables.
. generate two = 1+1
. generate mycars = 1 if (rep78==1 & price<5000) |
(rep78==2 & price<5000)
The –replace- command is used to make changes to existing
variables:
. generate domestic=0
. replace domestic = 1 if foreign==0
Remember that missing values are larger than numbers. So, if
you use –if- qualifier to indicate values larger than a specified
value, it could include missing values. For example, say, you
want to group cars into two categories by the repair rating,
high-repair-rating cars and low-repair-rating cars.
. generate hirep =1 if rep78>=3
. replace hirep = 0 if rep78<3
using Menus
Data=> Create or
change variables=>
Create new variable,
then click if/in tab,
select Create..., type
in criteria in the
window, click OK
Data=> Create or
change variables=>
Change contents of
variable
To exclude the missing values, you needed to specify:
. generate hirep =1 if rep78>=3 & rep78!=.
. replace hirep = 0 if rep78<3
Say, you want to group repair ratings into 3 groups. The easiest
way to re-group existing variables would be to use
–recode-. Giving an option of , gen(newrep78), the command
-recode- recodes REP78 into a new variable, NEWREP78,
instead of overwriting the existing variable, REP78.
. recode rep78 (1/2=1) (3/4=2) (5=3), gen(newrep78)
You normally want to use replace for
second and later steps in multi-step
variable creations. When you modify
existing variables, make sure you will still
have a way to recreate the original
variable or have a back-up copy of the
variable. Once you write over existing
variable, there is no way to get the
original data back.
. list hirep if rep78==.
Data=> Variable
utilities=> Keep or
drop variables=>
select Drop variables
HIREP also includes the cars whose repair records are missing.
Check it by listing the value of HIREP when REP78 is missing.
Now that we know HIREP contains missing values, let’s delete
the variable.
. drop hirep
Notes and Tips
Data=> Create or
change variables=>
Other variable
transformation
commands=>
Recode categorical
variable
Notice that hirep disappears from the
variables window. Once you delete a
variable, you can not undo the deletion.
If you issue a command –preservebefore removing a variable, you may
restore deleted variable by issuing a
command –restore-. This is a temporary
measure and only works as a set. Once
you issue –restore- command, you need
to issue another preserve command to
restore.
If you do not specify a new variable name
with the generate option, you will
overwrite the original variable. Let’s try
that with –preserve- and –restorecommands.
. tab rep78
. preserve
. recode rep78 (1/2=1) (3/4=2)(5=3)
. tab rep78
. restore
. tab rep78
gen is a short for generate.
Page 20 of 28
Typing commands in the Command window
We have already seen how to create a dummy variable (whose
outcome is either 0 or 1) using –generate- and –replace-.
Another easy way to create dummy variables is to use –
tabulate- command. The –tabulate- command, when used with
a generate option, produces dummy variables for each value.
For example, suppose we want to create a dummy variable for
each of the outcomes of the categorical variable REP78.
. tabulate rep78, gen(dumrep78)
Suppose you want to group a continuous variable, PRICE, into
five equal ranges. First find out the minimum and maximum
value that you want to use to group the PRICE by using –
summarize-. Then,
using Menus
Data=> Create or
change variables=>
Other variable
creation
commands=> Create
indicator variables
Data=> Create or
change variables=>
Create new variable,
then enter autocode
function in the box
. generate ivprice = autocode(price,5,3291,15906)
If you want to group PRICE into five groups of equal
frequencies, first sort PRICE, then issue the following
command:
. sort price
. generate fqprice = group(5)
Now, we have several more categorical variables to make a four
way table. Let’s create a table of repair records by HIREP by
IVPRICE by FOREIGN. Here is how:
. table rep78 hirep ivprice, by(foreign)
You can label the variables so that you know what they are later
on. Let’s add a label to HIREP as an example.
. label variable hirep “repair record is 3 or higher”
. label define yesno 1 “yes” 0 “no”
. lable values hirep yesno
Review Questions:
What is the command to
1. create new variables?
2. delete variables?
3. regroup variables?
4. group continuous variables?
5. create dummy variables?
Data=> Sort=>
Ascending sort
Statistics=>
Summaries, tables,
and tests=>
Tables=> Table of
summary
statistics(table)
Data=> Labels=>
Label variable
Data=> Labels=>
Label values=>
Define or modify
value labels
Notes and Tips
Scroll down the Variables Window to see
what Stata created. Alternatively, view
the list of variables by:
. describe
You can also add notes to the variables.
. note hirep: “temporary variable created
on October 1, 2006”
When you describe data, (-describe-) you
will see an asterisk (*) by the variable
label indicating that the variable hirep has
notes.
See the notes by typing
. notes
The maximum number of variables you
can list in –table- is three.
-label variable- adds a label to the
variable.
-label define- defines values of a lable.
The label name can be different from the
variable name, and can be used for other
variables.
-label values- attach label to the variable.
Data=> Labels=>
Label variable
Data=> Labels=>
Label values=>
Assign value labels
to variable
Hints:
. generate newvar =
. drop varnames
. recode oldvar (1/2=1) (3/4=2) (5=3),
gen(newvar)
. generate varname = group(5)
. generate newvar =
autocode(oldvar,5,min,max)
. generate newvar = 0
. replace newvar = 1 if oldvar > 6165
Page 21 of 28
7. Graph
Goal: view the relationships of the variables by graphing and save graphs.
Stata has several graphs for graphing distributions of individual variables, the relationship of the variables, as well as many more
specialized graphs. Shown here are commands for some basic graphs. You may explore graphs using the menus as well. In
Stata, graphs appear in separate windows that pop up. The graphs do not appear on the Results window, and will not be stored
in the log file. If you want to save the graphs, you will need to save each graph as a file.
Typing commands in the Command window
Here's a simple histogram of PRICE.
. histogram price
You can see the histogram separately for different groups.
For example, you can see a histogram of price for foreign
and domestic cars separately and have Y values in
frequency.
. histogram price, by(foreign) freq
Another popular graph is box plot. Let’s see box plots of
price by foreign.
. graph box price, by(foreign)
The basic command for drawing a bivariate graph is twoway.
The command twoway is followed by a keyword indicating
the type of graph. To obtain a scatter plot showing the
relationship between MPG and WEIGHT, type
. graph twoway scatter mpg weight
We can obtain the scatter plot by the car type, FOREIGN .
. graph twoway scatter mpg weight, by(foreign)
Twoway graphs can be overlaid: you can draw two twoway
graphs on the same set of axes. A common use of this is to
draw a scatterplot with a regression line laid overtop of it to
show how the regression line fits the data.
We will overlay scatter plot of with regression line fit for
MPG and WEIGHT.
. graph twoway (scatter mpg weight) (lfit mpg weight)
Let’s save the graph. On the Command Window, type:
. graph save OverlaidMpgWeight
Once it’s saved, close the graph window, and bring it up
again.
. graph use OverlaidMpgWeight
Review Questions:
How can I …
1. make a histogram of MPG?
2. see a scatter plot of MPG against WEIGHT?
3. fit a regression line over the previous scatter plot?
4. bring the graph up again after I close the graph
window?
using Menus
Graphics=> Histogram,
insert variable name PRICE
in the Variable: box and
check the box next to Bins,
change the number to 5
Graphics=> Box plot
Graphics=> Twoway
Graph, click Create, select
Scatter in the Basic plots:
box, Y variable: mpg, X
variable: weight, click
Accept, then in the “By” tab,
select Draw subgraphs...,
input foreign in Variables:
box
Graphics=> Twoway
Graph, click Create, select
Fit plots under plot
category, and Linear
prediction under Fit plots:,
Y variable: mpg, X variable:
weight
File=> Save Graph...
or
In the Stata Graph window,
File=> Save
File=> Open Graph...
Notes and Tips
For an introduction to Stata graphs,
type
. help graph intro
Default Y value of histogram is density.
To see the histogram in frequency or
percentage, type freq or percent after
a comma:
. histogram price, freq
To see more options, see
.help histogram
Typing scatter y x draws a graph of y
against x.
Here, scatter and lfit are plot types
within the twoway family. Alternatively,
you can use || to separate the plot
types.
. graph twoway || scatter mpg weight ||
lfit mpg weight
You do need to separate the plot types
by the parentheses or the pipes.
Hints:
. histogram
. graph twoway scatter
. graph twoway (scatter y x) (lfit y x)
. graph save
. graph use
Page 22 of 28
8. Obtain difference of means statistics
Goal: obtain Pearson’s chi-square, t-test, and analysis of variance statistics.
Once we reviewed the variables in the dataset, we may want to see the relationship among the variables. In the cross-tabulation
of repair records obtained above, domestic cars appeared to have poorer frequency-of-repair records. Is the difference
statistically significant? Let’s obtain a chi-square statistic to test the hypothesis that the frequency-of-repair records are different
by the car type.
Typing commands in the Command window
using Menus
Notes and Tips
. tabulate rep78 foreign, chi2
Suppose we reviewed literature on the automobiles made
in 1978, and hypothesize that the average MPG of 1978
cars is 20. To test this hypothesis, do a one sample t-test.
. ttest mpg==20
Comparing domestic and foreign cars, it appears that the
average MPG differs by the car type. To test a hypothesis
that the MPG is the same for foreign and domestic cars,
let’s do a two-sample t-test.
. ttest mpg, by(foreign)
We suspect that MPG is really influenced by the cars’
repair records. I want to examine if the mean MPG is
significantly different among cars that have different repair
records.
. oneway mpg rep78
Suppose that we then decided to keep the impact of
foreign in the model in addition to the repair-record in
examining miles per gallon. To run two-way analysis of
variance,
. anova mpg rep78 foreign
What if I also wanted to see the impact of weight, which is
a continuous variable. Analysis of covariance can be done
in Stata using anova command, with continuous option.
. anova mpg rep78 foreign weight, continuous(weight)
Review Questions:
How do I obtain…
1. a chi-square statistic.
2. t-test statistics?
3. one-way ANOVA statistics?
4. two-way ANOVA statistics?
Statistics=> Exact statistics=>
Two-way tables with measures
of association=> select
Likelihood-ratio chi-squared
Statistics=> Summaries, tables,
and tests=> Classical tests of
hypotheses => One-sample
mean-comparison test
Statistics=> Summaries, tables,
and tests=> Classical tests of
hypotheses => Two-sample
mean-comparison test, in
“by/if/in” tab, select Repeat
command by groups, then input
foreign in Variables taht define
groups:
One way analysis of variance tests
whether the means of mpg differ
across categories of repair record.
If instead I wanted to see the mean
difference by foreign, one way
result is the same as ttest result,
as the variable foreing only has
two categories.
Statistics=> Linear models and
related=> ANOVA/MANOVA=>
One-way ANOVA
Statistics=> Linear models and
related=> ANOVA/MANOVA=>
Analysis of variance and
covariance
To learn more about ttest, oneway,
or anova, use help.
Hints:
. tabulate varnames, chi2
. ttest
. oneway
. anova
Page 23 of 28
9.
Obtain linear regression estimates
Goal: run a multiple linear regression model.
Typing commands in the Command window
In estimating relationships among variables, you may
first want to examine how the variables are correlated.
We suspect that MPG and WEIGHT are correlated.
Let’s see the correlation:
. correlate mpg weight
In addition, we suspect that the correlation may be
different between foreign and domestic cars. We can
combine the –correlate- command with a by statement.
Before using a by statement, the data need to be sorted
by the by-variable.
. sort foreign
. by foreign: correlate mpg weight
It seems that mpg and weight have a relatively high
correlation. The correlation is different for foreign and
domestic cars, so foreign must also impact MPG.
using Menus
Statistics=> Summaries, tables,
and tests=> Summary and
descriptive statistics=>
Correlations and covariances
. pwcorr mpg weight, star(.05)
adds an asterisc (*) next to the
correlation coefficients that are
statistically significat at 95% level.
Data=> Sort=> Ascending sort
You can also sort and use “by
statement” in one step:
. bysort foreign: correlate mpg weight
Statistics=> Summaries, tables,
and tests=> Summary and
descriptive statistics=>
Correlations and covariances, in
“by/if/in” tab click Repeat
command by groups, insert
foreign in Variables that define
groups:
From the scatterplots we saw earlier, we also discovered
that the relationship between WEIGHT and MPG is
not exactly linear. We’ll include a square of WEIGHT
to improve the model. Let’s run a regression estimating
MPG by WEIGHT, WEIGHT2 and FOREIGN.
. regress mpg weight weight2 foreign
Statistics=> Linear models and
related=> Linear regression
After estimating a regression model, we can use the
values estimated by the model, called post-estimation
values. Using estimated MPG, we can see how the
estimated line fit the original distribution by viewing
overlaid graph. To do so, we first need to create a
variable for the predicted MPG. We’ll call this
MPGHAT.
Statistics=> Postestimation=>
Predictions, residuals, etc.,
. predict mpghat
. graph twoway (scatter mpg weight) (line mpghat
weight), by (foreign)
Review Questions:
1. What is the correlation between MPG and
WEIGHT?
2. Is the correlation different between domestic
and foreign cars?
3. How do I obtain regression estimates?
4. How can I compare observed and predicted
values on a graph?
Notes and Tips
Graphics=> Two-way graph
(if there are already defined
plots in “Plot definitions:”, either
Disable or Edit them to create
new combinations)
There are series of regression
diagnostics you can do using graphs.
See UCLA’s Stata tutorial site for
more information.
To compute a square of WEIGHT,
WEIGHT2, you can multiply WEIGHT
by itself, or raise it to the power of 2.
. generate weight2 = weight*weight
. generate weight2 = weight^2
do the same thing.
Stata has a series of “post estimation
commands.” After running a
regression estimates, for example,
you can test if the coefficients are
statistically significantly different from
0, or from another independent
variable (wald test), or test for
heteroscedasticity. For details, see
. help regress postestimation
,xb that appear as an option when
menu is used is a default in
command window input. It will not
appear in the Results window when
command is input in the Command
window.
Hints:
. correlate
. by varname: correlate
. regress
. predict yhat
. graph two way (scatter y x) (line
yhat x)
Page 24 of 28
10. Do files
When you have rather intense computations or repeat/modify existing computations, it may be helpful for you to
create a file that contains a set of Stata commands. Such files are called “do files” in Stata. Do files can be created
by manually entering commands in any text editors, or using Stata’s do-file editor. In Stata, do-file editors can be
invoked by:
CMD: .doedit
MNU: Window=> Do-file editor=> New do-file
You may also create do-files by saving commands you submit interactively. When you start a Stata session, start
“command log,” which is a log file with only the commands. It by default attaches .txt file extension if you do not
specify the extension. If that is the case, you can change it in Window’s file explorer. For this command, I have not
found a menu version.
CMD: .cmdlog using filename.do
If you forget to start a command log, you may save the commands in the Review window. First, right click in the
Review window then, select “Select All”. Right click in the Review window again, then select “Send to Do-file
Editor”. You can eliminate error commands by clicking the _rc on top of the Review window, which sorts the
commands by the errors, then select the error commands, right click, then “Delete”. You can resort the commands
in the original order by clicking the top of the numbered column on the far left. For the same token, you can sort
the commands by clicking the top bar where it says “Command” and delete commands like –browse- and –help-.
By the way, if you use menu for help and search, they do not appear on the Review or Results window.
11. Shortcut menus
Open dofile
editor
Open data
editor
Open data
browser
Open data
Quit4
Save data
Print results
Log 1
Open/ close
viewers
Graph
window 2
Scroll
Results
window3
1. Begins log if no log file is open. If a log file is open, it lets you view, close, or suspend the log. You may append
to the previous log by selecting an existing log file. Dialog box menu changes accordingly.
2. Moves graph window upfront. It only becomes active when a graph window is open.
3. Scrolls the Results window one screen at a time, when you have –more- at the bottom of the Results window. It
is equivalent to hitting the space bar or clicking –more4. Quit processing. Useful when a process is taking a log time and you want to stop the process, or when you have
–more- but do not want to see more. It is equivalent to hitting q in Command window or Ctrl-c at the same time.
Page 25 of 28
12. Exporting results
You can copy what appears in Results window by highlighting and right clicking. There are several options: Copy Text, Copy
Table, Copy Table as HTML, and Copy as Picture. Here are pasted tables for each.
Copy Text
If you are pasting tables into Excel, copying
Repair |
either as table or HTML will work well.
Record 1978 |
Freq.
Percent
Cum.
------------+----------------------------------If you are pasting tables into Word, copying
1 |
2
2.90
2.90
2 |
8
11.59
14.49
as picture seems to produce the best
3 |
30
43.48
57.97
apperance. If you save them as picture,
4 |
18
26.09
84.06
though, modifying the contents can only be
5 |
11
15.94
100.00
done using a graphic software.
------------+----------------------------------Total |
69
100.00
Copy Table as HTML
Copy Table
Repair
Record 1978 Freq. Percent
1
2
3
4
5
2
8
30
18
11
2.90
11.59
43.48
26.09
15.94
Total 69
Repair
Cum.
2.90
14.49
57.97
84.06
100.00
100.00
Copy as Picture
Repair
Record 1978
Freq.
Percent
Cum.
1
2
3
4
5
2
8
30
18
11
2.90
11.59
43.48
26.09
15.94
2.90
14.49
57.97
84.06
100.00
Total
69
100.00
Record 1978
Freq. Percent
Cum.
1
2
2.90
2.90
2
8
11.59
14.49
3
30
43.48
57.97
4
18
26.09
84.06
5
11
15.94
100.00
Total
69
100.00
Log files with extension .log can be opened in Word. Log files with extension .smcl will show the tags for Stata. See the
command in the next section to convert .smcl files into .log files.
Graphs saved as a picture (see section 7. Graph) can be imported into a document. There are several options for the format.
Use the drop down list in Save As box for the selection. Graphs can also be copied and pasted into another application like MS
Word. Right click the graph you want to copy, then select Copy Graph. Paste the graph in Word using Edit=> Paste, right
click and Paste, or hit Control and v at the same time. When the graphs are copied into Word 2003, they may not appear
correctly when the file is converted into Word 2007.
There are also user created commands to output results. You may check out commands such as outreg, outreg2, estout, tabout,
est2tex, mktab, and xml_tab. To read about the commands, use search. For example, type in Stata’s command window,
. search outreg, all
Note about user created commands: Stata, being a programmer friendly program, makes it easy to install and use user made
commands. If you see a user made command that you want to use, you can install it by first finding the command by searching
for it (you can also type -findit- commandname in Stata’s Command window) and clicking the blue letters “click here to install.”
The help pages on the commands become available after installing the program.
Page 26 of 28
13. Other helpful commands
If working with a large file:
You can describe data without loading the data by specifying the location and the name of data file.
. describe using datafilename
You can load only the variables you need by specifying the variable names.
. use var1 var2 var3 using datafilename
Some commands produce a log that is more than a page long (-compress-, for example). To save yourself from
pressing a key to scroll each page, you may use
. set more off
If you are seeing –more- at the end of the screen after typing search, and want to quit seeing more screens, press
q or control and c keys at the same time. Clicking red X button does the same thing.
You can save some memory by compressing the data.
. compress
Shortcuts
Stata can fill in a variable name with a tab key aftrer enough characters to recognize the name are entered. For
example, while you have the auto data open, try:
. describe h [hit tab key]
Stata fills in the rest of the variable name as headroom
You can bring up previously used commands in the Command window by hitting Page Up key.
You can refer to a set of variables with the same stem using an asterisc (*), as in:
. describe weight*
if you had created weight2, it will show both weight and weight2
Miscellaneous
If you forget to start a log file at the beginning of a Stata session, but want to save what you have in the output
window, use
. translate @Results outputfilename.txt
The file can be viewed using a text editor or a word processor.
Note: -translate- only saves what is in the buffer (what you see in the Results window). Depending on the length of
the output you had produced, earlier results may have been lost. It is a good habit to start a log file each time you
start a Stata session.
If you created Stata log file that has a file extension .smcl, you can reformat it into a text file by giving the command:
. translate filename.smcl
filename.log
If you want to perform a mathematical operation on the spot, you can use the –display- command.
. display 1+1 => will return 2
Page 27 of 28
14. On-line tutorials
UCLA
http://www.ats.ucla.edu/stat/stata/
UNC
http://www.cpc.unc.edu/services/computer/presentations/statatutorial/
Princeton
http://data.princeton.edu/stata/
http://www.princeton.edu/~eszter/stata.html
http://www.princeton.edu/~otorres/Stata/
http://opr.princeton.edu/computing/software/stata/intro/default.asp
15. References
Hamilton, Lawrence C. 2006. Statistics With Stata. Updated for Version 9. Pacific Grove, CA: Duxbury Press.
Stata Corporation. 2008. Using Stata Effectively: Data Management, Analysis, and Graphics Fundamentals.
Data and Statistical Services, Princeton University. Fall 2007. Stata Hands-on Instruction Guide. Windows version
9.0.
Page 28 of 28