forked from phc/dm-scripts
Compare commits
10 Commits
removeproo
...
main
| Author | SHA1 | Date |
|---|---|---|
|
|
4fa77291b6 | 9 months ago |
|
|
6fefa2d561 | 1 year ago |
|
|
27b8e7cdf1 | 1 year ago |
|
|
58e2abfdca | 2 years ago |
|
|
11e3ce8dcd | 2 years ago |
|
|
9c7faa0006 | 2 years ago |
|
|
2a06044973 | 2 years ago |
|
|
5310ac5f2f | 2 years ago |
|
|
2731ce32d3 | 2 years ago |
|
|
3797119bb5 | 2 years ago |
@ -0,0 +1,58 @@
|
|||||||
|
import {createWriteStream} from 'fs';
|
||||||
|
import {JSDOM} from "jsdom";
|
||||||
|
import fetch from "node-fetch";
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
try {
|
||||||
|
const url = process.argv[2];
|
||||||
|
if (!url) {
|
||||||
|
console.error("Usage: node script.js <registro_link>");
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
const response =
|
||||||
|
await fetch(url, {headers : {"User-Agent" : "Mozilla/5.0"}});
|
||||||
|
const buffer = await response.arrayBuffer();
|
||||||
|
const isoHtml = Buffer.from(buffer, "binary").toString("latin1");
|
||||||
|
|
||||||
|
const dom = new JSDOM(isoHtml);
|
||||||
|
const document = dom.window.document;
|
||||||
|
|
||||||
|
let ol = document.querySelector("ol");
|
||||||
|
if (!ol) {
|
||||||
|
console.error("No <ol> found on the page");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
ol.querySelectorAll("a, i").forEach(el => el.remove());
|
||||||
|
|
||||||
|
const results = [...ol.children ]
|
||||||
|
.map(li => li.textContent.match(/\w+:(.+)/sm))
|
||||||
|
.filter(match => match)
|
||||||
|
.map(match => match[1].trim())
|
||||||
|
.map((x, index) => (index + 1) + ". " + x + " \n");
|
||||||
|
|
||||||
|
const writeStream = createWriteStream("registro.md")
|
||||||
|
const pathName = writeStream.path;
|
||||||
|
writeStream.on('error', function(err) { /* error handling */ });
|
||||||
|
const head = "# Registro delle lezioni \n\n";
|
||||||
|
writeStream.write(head)
|
||||||
|
results.forEach(value => writeStream.write(`${value}`));
|
||||||
|
// the finish event is emitted when all data has been flushed from the
|
||||||
|
// stream
|
||||||
|
writeStream.on(
|
||||||
|
'finish',
|
||||||
|
() => { console.log(`Registro salvato nel file ${pathName}`); });
|
||||||
|
|
||||||
|
// handle the errors on the write process
|
||||||
|
writeStream.on(
|
||||||
|
'error',
|
||||||
|
(err) => {console.error(
|
||||||
|
`There is an error writing the file ${pathName} => ${err}`)});
|
||||||
|
|
||||||
|
// close the stream
|
||||||
|
writeStream.end();
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error fetching or processing page:", error);
|
||||||
|
}
|
||||||
|
})();
|
||||||
@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Create the pdf folder if it doesn't exist
|
||||||
|
mkdir -p pdf
|
||||||
|
|
||||||
|
# Iterate through all .pptx files in the current folder
|
||||||
|
for file in *.pptx; do
|
||||||
|
if [ -f "$file" ]; then
|
||||||
|
# Extract the base name (without extension) of the file
|
||||||
|
base_name=$(basename "$file" .pptx)
|
||||||
|
|
||||||
|
# Convert the .pptx file to .pdf and save it in the pdf folder
|
||||||
|
libreoffice --headless --convert-to pdf --outdir pdf "$file"
|
||||||
|
|
||||||
|
echo "Converted $file to pdf/$base_name.pdf"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Conversion complete!"
|
||||||
|
|
||||||
@ -0,0 +1,47 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ $# -ne 2 ]; then
|
||||||
|
echo "Usage: $0 input.tex output.md"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
input_file="$1"
|
||||||
|
output_file="$2"
|
||||||
|
|
||||||
|
# Funzione per convertire le sezioni
|
||||||
|
convert_section() {
|
||||||
|
local level=$1
|
||||||
|
local name=$2
|
||||||
|
echo -e "$(printf '#%.0s' $(seq 1 $level)) $name\n" >> "$output_file"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Funzione per convertire definizioni, teoremi e proposizioni
|
||||||
|
convert_definition_or_theorem_or_proposition() {
|
||||||
|
local type=$1
|
||||||
|
local name=$2
|
||||||
|
if [[ $type == "teorema" || $type == "proposizione" ]]; then
|
||||||
|
echo "* [ ] [**$type**] $name" >> "$output_file"
|
||||||
|
else
|
||||||
|
echo "* [ ] [$type] $name" >> "$output_file"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Inizializza il file di output
|
||||||
|
> "$output_file"
|
||||||
|
|
||||||
|
# Leggi il file .tex e converti le sezioni, definizioni, teoremi e proposizioni
|
||||||
|
while IFS= read -r line; do
|
||||||
|
if [[ $line =~ \\section\{(.+)} ]]; then
|
||||||
|
convert_section 1 "${BASH_REMATCH[1]}"
|
||||||
|
elif [[ $line =~ \\subsection\{(.+)} ]]; then
|
||||||
|
convert_section 2 "${BASH_REMATCH[1]}"
|
||||||
|
elif [[ $line =~ \\subsubsection\{(.+)} ]]; then
|
||||||
|
convert_section 3 "${BASH_REMATCH[1]}"
|
||||||
|
elif [[ $line =~ \\begin\{definition\}\[(.+)\] ]]; then
|
||||||
|
convert_definition_or_theorem_or_proposition "definizione" "${BASH_REMATCH[1]}"
|
||||||
|
elif [[ $line =~ \\begin\{theorem\}\[(.+)\](\{.+})? ]]; then
|
||||||
|
convert_definition_or_theorem_or_proposition "teorema" "${BASH_REMATCH[1]}"
|
||||||
|
elif [[ $line =~ \\begin\{proposition\}\[(.+)\] ]]; then
|
||||||
|
convert_definition_or_theorem_or_proposition "proposizione" "${BASH_REMATCH[1]}"
|
||||||
|
fi
|
||||||
|
done < "$input_file"
|
||||||
Loading…
Reference in New Issue