From 83e0ea6027294545dba4442a42e60a153050faa4 2012-05-13 23:08:34 From: Min RK Date: 2012-05-13 23:08:34 Subject: [PATCH] Merge pull request #1686 from punchagan/notebook-cmd-line ENH: Open a notebook from the command line open notebook files from the command line, just like ipython can open (run) python files. For example: ipython notebook foo.ipynb closes #945 --- diff --git a/IPython/frontend/html/notebook/notebookapp.py b/IPython/frontend/html/notebook/notebookapp.py index b157c97..8e9b813 100644 --- a/IPython/frontend/html/notebook/notebookapp.py +++ b/IPython/frontend/html/notebook/notebookapp.py @@ -257,6 +257,9 @@ class NotebookApp(BaseIPythonApplication): # create requested profiles by default, if they don't exist: auto_create = Bool(True) + # file to be opened in the notebook server + file_to_run = Unicode('') + # Network related information. ip = Unicode(LOCALHOST, config=True, @@ -376,6 +379,10 @@ class NotebookApp(BaseIPythonApplication): # Kernel should inherit default config file from frontend self.kernel_argv.append("--KernelApp.parent_appname='%s'"%self.name) + if self.extra_args: + self.file_to_run = os.path.abspath(self.extra_args[0]) + self.config.NotebookManager.notebook_dir = os.path.dirname(self.file_to_run) + def init_configurables(self): # force Session default to be secure default_secure(self.config) @@ -524,9 +531,20 @@ class NotebookApp(BaseIPythonApplication): browser = webbrowser.get(self.browser) else: browser = webbrowser.get() - b = lambda : browser.open("%s://%s:%i%s" % (proto, ip, self.port, - self.base_project_url), - new=2) + + if self.file_to_run: + filename, _ = os.path.splitext(os.path.basename(self.file_to_run)) + for nb in self.notebook_manager.list_notebooks(): + if filename == nb['name']: + url = nb['notebook_id'] + break + else: + url = '' + else: + url = '' + b = lambda : browser.open("%s://%s:%i%s%s" % (proto, ip, + self.port, self.base_project_url, url), + new=2) threading.Thread(target=b).start() try: ioloop.IOLoop.instance().start()