In case you are not familiar with Atom, each Jupyter kernel that you use is going to be installed in a slightly different way.
#Do file stata plus
I also installed Markdown Preview Plus (MPP), which provides a live updated preview of your document.
#Do file stata code
stata_kernel is the Jupyter kernel for Stata that allows the code to run interactively, Language Stata provides Stata lanugage support, and Language Markdown provides support for Markdown (including R Markdown).
#Do file stata install
To create an interactive document with Stata, you need to install Kyle Barron’s stata_kernel, the Language Stata package and the Language Markdown package. You can even run code for multiple kernels/languages in the same document. The best thing about Atom is that you can use the Hydrogen package to run code interactively. You can edit almost any language or document type, the color schemes are attractive and the keyboard shortcuts really help with efficiency. Here are some of the options I came across.
So I started a quest to figure out how I could best integrate Stata with Markdown in other environments. But I find that I still need Stata for certain kinds of analysis, and for some projects there is enough inertia that it makes sense to just keep doing them in Stata.Ī little while back, though, I found I just couldn’t stand working in Stata’s. I also find it really helpful from a workflow standpoint to be able to run code snippets in the text editor and to preview the document that I am writing in real time like you can in an R Notebook.Īt one point, I thought my solution would just abandon Stata entirely for R.
#Do file stata pdf
Anyone can download the archive and the code will run on any platform (Mac, PC, etc) without having to make a single change to adjust for file paths.Frequently when I am working in Stata, I find myself really missing the key features of R Markdown, like the ability to intersperse code with text and share my notes with other people in an attractive dynamic HTML or PDF document.
When work is finished on a project, you have a self contained project with all code, data, figures, and tables within a master directory (and a bunch of subdirectories, each of which can contain subdirectories, and so on) that can be zipped and submitted in support of a manuscript to a journal. Thus you can have a mature project with hundreds (or thousands) of do-files, each using and creating even more files (of any kind) and project will only re-run do-files that have changed since the last build AND do-files that must be run again because the files they use have changed as part of the ongoing build. If a do-file has not changed since the last build and none of the files it uses or creates have changed either, project will not run the do-file for the current build. This may appear inefficient, especially as a project increases in size and complexity but project is smart and can track changes in do-files. With project, you never run a do-file in isolation, you always rebuild the whole project. The fastcd package, available on SSC, obviates the small inconvenience of having to change to the appropriate working directory to start with.Ĭode: project xyz, build and project will then run the master do-file. Similarly, it's not a problem that my computer "sees" the SuperProject folder at /Users/Glenn/Dropbox/SuperProject, but my co-author's computer sees it at C:\Users\Eddy\Dropbox\Super Project. Now I can move the "SuperProject" folder anywhere I want and everything works fine. Graphs can be saved as "./Graphs/Graph1.gph", etc. They can reference raw data files (which are stored in //SuperProject/Data) as "./Data/file1.dta". For example, for the project "SuperProject", my do files will always be in //SuperProject/Models. Relative files work very well from this, so long as you maintain a constant directory structure for each project. It is then the user's responsibility to change the working directory to the appropriate directory before running the do-file. The practice I've developed with co-authors is to not include a "base" directory in my do-files.