gophernotes
is a Go kernel for Jupyter notebooks. Finally, we can have a reliable and maintained way to use Go interactively and code in the browser. Use gophernotes
to create and share documents that contain live Go code, equations, visualizations and explanatory text. These notebooks, with the live Go code, can then be shared with others via email, Dropbox, GitHub and the Jupyter Notebook Viewer. Go forth and do data science, or anything else interesting, with go notebooks!
This project came out of the Gopher Gala 2016. It is inspired by a REPL called gore and by a, no longer maintained and self-described as limited, ipython kernel call iGo.
Example Notebooks (dowload and run them locally, follow the links to view in Github, or use the Jupyter Notebook Viewer):
- Simple Printing and Channels
- Pattern Recognition with Golearn
- Feed Forward, Recurrent Neural Nets
- Time Parsing, Formatting
- Stateful Goroutines
- Worker Pools
-
Dependencies:
-
Create a workspace and setup your
GOPATH
, see https://golang.org/doc/code.html#GOPATH -
Install
goimports
if you haven't already:go get golang.org/x/tools/cmd/goimports
-
Get the kernel:
go get github.com/gophergala2016/gophernotes
-
Create a directory for the new kernel config:
mkdir -p ~/.ipython/kernels/gophernotes
-
Copy the kernel config into the
.ipython
directory:cp -r $GOPATH/src/github.com/gophergala2016/gophernotes/kernel/* ~/.ipython/kernels/gophernotes
-
Start the jupyter notebook:
jupyter notebook
-
Select
Golang
from theNew
drop down menu. -
Have Fun!
Possible Issues:
- Depending on your environment, you may need to manually change the path to the
gophernotes
executable inkernel/kernel.json
before copying it to~/.ipython/kernels/gophernotes
. You can put the full path to thegophernotes
executable here, and you shouldn't have any further issues.
-
Pull down and run the latest image:
docker pull dwhitena/gophernotes:latest docker run --name gophernotes --net host -d dwhitena/gophernotes:latest
-
Point your browser to
localhost:8888
. -
Select
Golang
from theNew
drop down menu. -
Have Fun!
Possible issues:
-
For OSX Docker Machine / Dlite users, you may need to set the IP to
0.0.0.0
instead of the defaultlocalhost
with:docker run --net host -d dwhitena/gophernotes jupyter notebook --ip=0.0.0.0
Note - this is a pretty large image, because it contains a full distribution of Anaconda plus the add ons of gophernotes. However, with this image, you can create Go notebooks, Python notebooks, text files, run ipython in the shell, etc.
Some of the custom commands from the gore REPL have carried over to gophernotes
. Note, in particular, the syntax for importing packages:
:import <package path> Import package
:print Show current source (currently prints to the terminal where the notebook server is running)
:write [<filename>] Write out current source to file
:help List commands
:containerize Build a Docker image that executes the compiled Go code (must have Docker installed)
gophernotes
was created by Daniel Whitenack, and is licensed under an MIT-style License.
The Golang Gopher image was created by Takuya Ueda and is licensed under the Creative Commons 3.0 Attributions license.