ExtractSolution¶
Generate mdx files from solutions
Once you have solved a question, you can generate an mdx file with the solution and the question statement using the ExtractSolutions
class:
from leetscrape import ExtractSolutions
# Get the question body
solutions = ExtractSolutions(filename="<path-to-solution-file>").extract()
Solution
objects with the following attributes:
solution.id # Solution ID
solution.code # Solution code
solution.docs # Docstrings associated with the solution
solution.problem_statement # Question body / problem statement
Alternatively, you can use the to_mdx
method to generate the mdx file:
from leetscrape import ExtractSolutions
# Get the question body
ExtractSolutions(filename="<path-to-solution-file>").to_mdx(output_filename="<path-to-output-file>")
Source code in src/leetscrape/extract_solution.py
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 |
|
extract(top_class_name='Solution')
¶
Extract solutions from a given python file.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
filename |
str
|
The path of the file to extract solutions from. This python script should have the solution method(s) in the class named in the top_class-name. |
required |
top_class_name |
str
|
The name of the class from which to extract the solutions from. Defaults to `Solution’. |
'Solution'
|
Raises:
Type | Description |
---|---|
ValueError
|
When the filename does not follow the required convention of |
ValueError
|
When the provided python file does not have a class named Solution. |
Returns:
Type | Description |
---|---|
list[Solution]
|
list[Solution]: A list of solutions, each containing an id, code [and docs]. |