All Projects → grantps → superhelp

grantps / superhelp

Licence: MIT license
Python help that really helps

Programming Languages

python
139335 projects - #7 most used programming language
Jupyter Notebook
11667 projects

Projects that are alternatives of or similar to superhelp

Creative Scala
Quick, graphical, fun introduction to programming in Scala.
Stars: ✭ 171 (+533.33%)
Mutual labels:  learn-to-code
30 Seconds Of Angular
[WIP] Curated collection of Angular snippets that you can understand in 30 seconds or less
Stars: ✭ 221 (+718.52%)
Mutual labels:  learn-to-code
Freecodecamp
freeCodeCamp.org's open-source codebase and curriculum. Learn to code for free.
Stars: ✭ 339,510 (+1257344.44%)
Mutual labels:  learn-to-code
How To Markdown
Learn how to start using Markdown
Stars: ✭ 173 (+540.74%)
Mutual labels:  learn-to-code
30 Seconds Of Php
Short PHP code snippets for all your development needs
Stars: ✭ 2,461 (+9014.81%)
Mutual labels:  learn-to-code
Cracking The Coding Interview Rust
Cracking the Coding Interview problem solutions in Rust
Stars: ✭ 246 (+811.11%)
Mutual labels:  learn-to-code
React Tutorial Exercises
Learn and practice React.js in this interactive tutorial with dozens of react exercises.
Stars: ✭ 161 (+496.3%)
Mutual labels:  learn-to-code
go-decorator-pattern
golang and decorators / decorator patterns
Stars: ✭ 134 (+396.3%)
Mutual labels:  learn-to-code
Python Awesome
Learn Python, Easy to learn, Awesome
Stars: ✭ 219 (+711.11%)
Mutual labels:  learn-to-code
You Dont Know Js
A book series on JavaScript. @YDKJS on twitter.
Stars: ✭ 147,493 (+546170.37%)
Mutual labels:  learn-to-code
Blocklike
Bridging the gap between block programming and JavaScript.
Stars: ✭ 177 (+555.56%)
Mutual labels:  learn-to-code
Javascript
GitBook teaching programming basics with Javascript
Stars: ✭ 2,525 (+9251.85%)
Mutual labels:  learn-to-code
Chigraph
A visual systems language for beginners compiled using LLVM
Stars: ✭ 247 (+814.81%)
Mutual labels:  learn-to-code
Hackclub
🏫 Hack Club is a nonprofit network of computer science clubs where members learn to code through tinkering and building projects
Stars: ✭ 2,139 (+7822.22%)
Mutual labels:  learn-to-code
memcheck-cover
An HTML generator for Valgrind's Memcheck tool
Stars: ✭ 30 (+11.11%)
Mutual labels:  code-quality
Go Monkey
Code for "Writing An Interpreter in Go"
Stars: ✭ 168 (+522.22%)
Mutual labels:  learn-to-code
30 Seconds Of Css
Short CSS code snippets for all your development needs
Stars: ✭ 14,945 (+55251.85%)
Mutual labels:  learn-to-code
javascript-test-reporter
DEPRECATED Code Climate test reporter client for JavaScript projects
Stars: ✭ 68 (+151.85%)
Mutual labels:  code-quality
effective-code-review
Presentation about my process for making code reviews as effective as possible
Stars: ✭ 63 (+133.33%)
Mutual labels:  code-quality
30 Seconds Of Code
Short JavaScript code snippets for all your development needs
Stars: ✭ 89,121 (+329977.78%)
Mutual labels:  learn-to-code

https://github.com/grantps/superhelp

Example HTML output

version number: 1.9.2 author: Grant Paton-Simpson

Overview

SuperHELP is Help for Humans! The goal is to provide customised help for simple code snippets. SuperHELP is not intended to replace the built-in Python help but to supplement it for basic Python code structures. SuperHELP will also be opinionated. Help can be provided in a variety of contexts including the terminal and web browsers (perhaps as part of on-line tutorials).

Quick Start

Click the button below to open a Binder Jupyter Notebook you can play around in e.g. get advice on a snippet or line of Python

Binder

or put the following at the top of your Python script and run the script:

import superhelp
superhelp.this()

Installation

Note - Python 3.9+ only. If you have an older version of Python use the Binder Jupyter Notebook button instead (see higher up)

To install

Note

  1. Use pip

E.g.

$ python3 -m pip install superhelp

Check by running

$ shelp

If it doesn't work, and you are on Linux, adding the following to your .bashrc file might fix the problem:

export PATH=$PATH:~/.local/bin
  1. Or clone the repo

    $ git clone https://github.com/grantps/superhelp.git $ python3 setup.py install

Example Use Cases

  • Charlotte likes to check her code before others see it so includes

      import superhelp
      superhelp.this(warnings_only=True)
    

    at the top of each script. When she is happy with the code she comments those two lines out.

  • Avi is a Python beginner and wants to get advice on a five-line function he wrote to display greetings to a list of people. He learns about Python conventions for variable naming and better ways of combining strings.

  • Zach wants to get advice on a named tuple. He learns how to add doc strings to individual fields.

  • Noor is considering submitting some code to Stack Overflow but wants to improve it first (or possibly get ideas for a solution directly). She discovers that a list comprehension might work. She also becomes aware of dictionary comprehensions for the first time.

  • Al has written a simple Python decorator but is wanting to see if there is anything which can be improved. He learns how to use functool.wrap from an example provided.

  • Moana is an experienced Python developer but tends to forget things like doc strings in her functions. She learns a standard approach and starts using it more often. Moana also finds the summarised linting useful.

  • Paul wants to check the quality of some code before including it in his project. He learns about some issues and makes improvements before integrating it.

Example Usage

Screenshot from HTML output

Example HTML output

Screenshot from Terminal output

Example Terminal output

Terminal themes available ('dark' and 'light')

Example Terminal themes

Screenshot from Markdown output

Example Markdown output

Using SuperHELP on the Notebook

Add new cell at end with content like:

%%shelp

def sorted(my_list):
    sorted_list = my_list.sort()
    return sorted_list

and run it to get advice.

The notebook has more detailed instructions at the top.

Using SuperHELP on a Local Installation

Inside your script

Put the following at the top of your script and then run the script (note - there are two underscores on either side of file):

import superhelp
superhelp.this()

If you don't want the default web output you can specify another output such as 'cli' (command line interface) or 'md' (markdown):

import superhelp
superhelp.this(output='md')

If you don't want the default 'Extra' level of messages you can specify a different detail level ('Brief' or 'Main') e.g.

import superhelp
superhelp.this(detail_level='Brief')

or:

import superhelp
superhelp.this(detail_level='Main')

If you only want to see warnings you can specify warnings only e.g.

import superhelp
superhelp.this(warnings_only=True)

Executing your code allows SuperHELP to better understand your code.

If you want your code executed while SuperHELP is evaluating it

import superhelp
superhelp.this(execute_code=True)

You can use as many options as you want e.g.

import superhelp
superhelp.this(output='md', execute_code=True, warnings_only=True)

From the command line (terminal / console)

$ shelp -h  ## get extended help on usage (purpose, defaults, etc)

$ shelp --code "people = ['Tomas', 'Sal', 'Raj']" --output html --detail-level Main
$ shelp -c "people = ['Tomas', 'Sal', 'Raj']" -o html -d Main

$ shelp --file-path my_script.py --output cli --theme light --detail-level Extra
$ shelp -f my_snippet.py -o cli -t light -d Extra

$ shelp --project-path /home/g/proj --exclude-folders env
$ shelp -p /home/g/proj -e env

$ shelp --file-path my_script.py --warnings-only
$ shelp -f my_snippet.py -w

$ shelp --file-path my_script.py --execute-code
$ shelp -f my_snippet.py -x

$ shelp  ## to see advice on an example snippet displayed (detail level 'Extra')

$ shelp --advice-list  ## to see all types of help listed
$ shelp -a

Stretch Ideas

  • Extend beyond standard library into popular libraries like requests, bottle, flask etc.

Other Packages

https://github.com/aroberge/friendly-traceback

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].