Continue to Site

Eng-Tips is the largest engineering community on the Internet

Intelligent Work Forums for Engineering Professionals

  • Congratulations waross on being selected by the Eng-Tips community for having the most helpful posts in the forums last week. Way to Go!

Jupyter Lab Notebook Calculation Sheet

Brad805

Structural
Oct 26, 2010
1,493
I have been working on a project to create more of my calculation sheets using Jupyter Lab or Notebooks. I did not like the look of the output, so I went searching for options to improve the quality of the calculation sheets. This turned out to be a bit of a headache given how little I understand how CSS styles, HTML and LaTex work. I have finally found a partial solution to achieve what I want. Below is two sheets from a sample Jupyter notebook. If anyone is interested I can share details on the workflow. The setup process was not great, but once that is done the processs only involves creating a HTML file that can be converted into a .pdf using puppeteer. Going forward I hope I can use MYST markdown to import documents from all sorts of software packages to organize the file in a complete manner, but that will take a bit more time.

JupyterLab_example.pngJupyterLab_example2.png
 
Replies continue below

Recommended for you

Hey Brad805,
Can you share the workflow with me? I've been off and on the Python/Jupyter wagon for some time. Ultimately I haven't pursued it because I couldn't get the PDF print that I so often need for my notes...moved on to quicker, brute force methods with other software. But I would like to actually get this nailed down at some point.
Send me a message or expand on this thread when you have time.
Thanks!
 
Sure. The reason I posted was to see if anyone else wanted some ideas. I did not find a ton of great examples when I started, so I thought others might be interested. I will share a number of things for the benefit of others, so do not be annoyed if I drone on a bit.

I started looking into using python after watching some different you tube videos suggesting engineers should be thinking about using Python in practice. Over the past few years I have found a number use cases, and with AI, you can start without being an expert programmer like Celt, Sticks, or IDS. I have found a ton of examples where people go on and on about creating a web app, but honestly, have close to zero interest in that. I have no aspirations of becoming some expert coder that comes up with something to sell. I am old and tired of some stupid daily tasks I must complete to do my work. The goal at the end of this is to spit out a .pdf to put in a file. I am getting closer to having that.

The first thing to think about is how fancy you want your output. It is easy to get things to display nicely on your screen with html, but to convert that to a .pdf that most of us want can involve a few steps. Tables and engineering variables have proven to be the biggest hurdle for me. I will share a bit about my testing of both separately.

Most in the PHd world are using LaTex to create their pretty documents in the standard format their institution requires. A common tool most seem to use is Overleaf. I tried that, but it does not work well if you want to avoid copying values from one document to another. It is great for making assigments if you are into that kind of thing. I would not mention this if not for the fact that using LaTex in your coding is very useful to create nice looking documents.

Tables, ahh, such an important thing for us. This is probably the most valuable part of Python for a structural engineer. I routinely export multiple spreadsheets from SAP2000 and do the same stupid editting to each sheet. Such a waste of time. I will be dumping complete data sets into python in the future to post process them. Once I create a definition, it will redo the task in seconds exactly the same each time. Now why are tables a problem? There are a few differnt ways you can create them in python, but those look terrible to me. You can code fairly decent looking tables using LaTex, but I would like the tables as I am working. The advantage of LaTex, is you can create a .pdf with that. Direct creation of the .pdf using LaTex is very nice since it allows you to contols endless parameters very efficiently. I decided to use HTML and CSS coding for my tables. This allows you to create very nice tables, but converting those to a .pdf file turned out to be a pain. I am working on a 2D frame analysis tool (start below) for future projects, and it took hours yesterday to get the stupid tables from HTML to PDF, and then cropped so they display correctly. Now that I have completed the process I have general definitions that will work for data frames in the future very easily. You are probably thinking, but I do not know HTML coding or CSS very well. Neither do I. I worked with ChatGPT for a great number of hours going back and forth trying to get it to work. In the end, I am pleased with the result. If you start with ChatGPT you will quickly find you will need to pay for it unless you are more patient than I. The free version times out after so many interactions. I tried the AI within Jupyter as well, and am finding GPT works better to keep your interactions. There are tons of AI tools out there, and I am sure others know far more.

Now the engineering variables. Any of that have used Excel or other programming tools have used alternates to greek letters in their projects. Conner Ferster developed HANDCALCS to use in Python. It allows you to use proper greek letters in your code cells. This is wonderful since you can display your forumula exactly (or near enough) as you see in our code books. The downside is it uses CSS styling. That did not turn out super easy to get into a .pdf file, but I did eventually get it to work as you can see above. If you are fine with using f'c or phi_s for your variables, you may want to avoid this if you elect for a simple table output.

Now to your question. I will assume you want nicer looking tables and greek variables. It is not that difficult once setup, but it takes some patience to go thru the setup. I attached a .txt file with this that outlines the process for myself when I forget.

  1. The header in the calculation sheet is filled out using a small code cell at the start of the notebook (image below). This creates a small .json file that is stored in your project folder. Once that is created you do not need the code any longer unless you want to change it or use different project headings. In the example image you can see I was adding metadata to the project file. I tested that to see if I could get that to work, but I found the simple file was easier with the output I wanted.
  2. To control which code cells appear you need to set the metadata in your notebook. You can hide the cell input, output or complete block. When you create your html file these cells will still appear. Those rules are applied when you convert the html file to the pdf you want.
  3. To create the html file that is needed for the pdf creating you can simply File--> Save and export as ---> HTML. I do this usually from a terminal.
  4. To convert the html file to a .pdf I am using NBConvert. That applies the rules where text can be located, applies the cell metadata, and outputs the pdf.
If you avoid the complicated tables and variables, things are easier. In that case you could use MYST markdown, Quarto, or export direct to .pdf from Jupyter. If going straight from Jupyter you would need to setup the templates to work as you need and figure out how to make it use the metadata in your code book. I do not think that would be too difficult, but I am sure it will waste the better part of a day by the time you get it to work. To use MYST markdown you can create a template. They have videos. I did not go very far down that path given the parameters I set.

You will find more of the explanations in the text file. I know it seems like a collosal pain, but it is not. Creating the templates was a pain, but you have a basic outline you can edit. I think I will be able to use MYST markdown to create the html files in the future. The advantage of this is it will add a lot of useful feature to make a complete calculation book that has all your files in one place neatly referenced with a table of contents that does not involve manual work.

If you are looking for more python infomation I suggest:
  1. Timo Harboe Zollner. I recently found him on youtube and he has some helpful videos.
  2. Structural Python (Connor Ferster). Connor is a Canadian engineer. He was consulting, but it seems now he has moved towards teaching python. I do not follow the live coding streams many of these guys have, but it seems common amoung coders.

ENG-TIP_img2.png

ENG-TIP_img3.png


ENG-TIP_img1png.png
 

Attachments

  • PDF_From_JupyterLab(eng-tips).txt
    9.3 KB · Views: 2
Last edited:
Nice! I am going to chew into this closer to the end of the month once I start reeling in the business for the year. At that time, I may have some more questions or better insight in your process. Thanks for sharing!

Yes, I have taken PfSE with Connor and I'm currently in the ASYNC course (although I have not started...also something I will start in December). It was a really helpful course. I don't do much data wrangling with big SAP models or such, but the examples he provides are pretty adaptable.
 
How do you get in touch with Connor? I would like to get on the wait list for his training. I need to improve some of my basic skills so some aspects go faster.
 
I see a few are reading this, so I will add a bit more of the process I am working thru. My goal is to create a simple script to calculate member reactions. Most EORs in my area only include the factored reactions, and I waste a lot of time figuring out the dead/live/snow load values for delgated design work. Sure, I can ask for them, but most of the time that takes even longer. I have used excel sheets for a long time as well, but they are not general enough and I find myself editing them too much. Then at the end of the day some of the things I would like to see are hidden in the cell. I would like to speed up the process of calculating and documenting the analysis. I will have the option to run the analysis for multiple members and create reports.

To develop the script I am using a general frame setup so I can test different variables. I was looking at my first diagram, and decided it was too simple to test a number of cases. I decided to create a multi level frame like you see below. I first defined the frame manually, but that was time consuming, and prone to errors. I decided I needed to automate that. By adding gridlines I was able to find most of the main beam and column intersection points. I ordered the nodes in a logical manner like we engineers like. After that step one can define new nodes if one has a hinge joint like a gerber beam or something else. Once that was defined I re-ordered all the nodes again in a logical manner. From these nodes then all the members can be created. Again, the members are ordered in a logical sequence. All members are next assigned marks in the same order as the members. I will add the option to delete member and re-order the members. All of the diagram below is coded, and will scale based on the frame dimensions to fit the page.

I am realizing the code is getting a bit lengty. I think the final report may need to be a simple code to add all the tables I am creating. That is not great, but might be easier to read rather than scrolling thru endless lines of code. I will need to test that.

Ok, too much work. Some of this is a bit over the top. It is my way to test ideas. I will share a simple problem I was working on last night that all us bright people can figure out. I am moving on to the load cases now. I was working on this a bit last night. To think thru the steps I opened my code book. As I was looking at the table I wondered if I could code the table. Sure could and it was easy. I grabbed a .pdf screen shot of the table, and in about 5 minutes I re-created Table 4.1.3.2 using AI. The table is exceedingly similar to the table from the code. That does use my table function. Next, I wondered, hmm, can I create all the load cases in the same basic format to use for my code cells? Yes, in another 10minutes I had that too. I sitll need to check that, but it is a great start I think. All of this information is in a data frame that can be accessed later in the code. One can easily parse cases if your problem does not include all the load patterns.

Yell if I am annoying.

ENG-TIP_img6.png

ENG-TIP_img7.png



ENG-TIP_img4.png

ENG-TIP_img5.png
 
Last edited:
How do you get in touch with Connor? I would like to get on the wait list for his training. I need to improve some of my basic skills so some aspects go faster.

I think if you join the waitlist, he will send a newsletter out with updates. Otherwise, he has been responsive via LinkedIn.
 
Thanks. The script is working now. The last time I tried it did not seem to work, but maybe I had cache issue.
 
I was able to figure out printing a PDF of Jupyter Output via a script if anyone needs help.
 

Part and Inventory Search

Sponsor