Neculai Fantanaru

Everything Depends On The Leader

Hoe om Python-kode Google Translate-webwerf

On December 23, 2021
, in
Python Scripts Examples by Neculai Fantanaru

Jy kan die volledige kode hier sien: https://pastebin.com/rShSjcWY

Installeer Python. Installeer dan die volgende twee biblioteke met behulp van die Command Prompt (cmd) tolk in Windows10:

Python sal outomaties die volgende HTML-etikette met die googletrans-biblioteek vertaal:

py -m pip install "googletrans"
py -m pip install googletrans==4.0.0rc1
py -m pip install beautifulsoup4

Python-kode sal ook outomaties die inhoud van die volgende etikette (Jou teks) vertaal, maar slegs as hierdie etikette geraam word deur < ! -- ARTIKEL BEGIN --> en < ! -- ARTIKEL BEGIN --> html opmerkings. Natuurlik sal jy hierdie merkers met jou eie merkers moet vervang.

<!-- ARTICOL START -->
<h1 class="den_articol" itemprop="name">Your Text</h1>
<p class="text_obisnuit">Your Text</p>
<p class="text_obisnuit2">Your Text</p>
<span class="text_obisnuit2">Your Text</span>
<span class="text_obisnuit">Your Text</span>
<li class="text_obisnuit">Your Text</li>
<a class="linkMare" href="https://neculaifantanaru.com/af/">Your Text</a>
<h4 class="text_obisnuit2>Your Text</h4>
<h3 class="text_obisnuit2>Your Text</h3>
<h5 class="text_obisnuit2>Your Text</h5>
<!-- ARTICOL FINAL -->
             

DIE KODE: Kopieer en hardloop die kode hieronder in enige tolkprogram (ek gebruik pyScripter) . Moenie vergeet om die pad in die "files_from_folder" lyn. En hier is die lys tale wat vertaal kan word: LANG.

from bs4 import BeautifulSoup
from bs4.formatter import HTMLFormatter
import requests
import sys
import os
class UnsortedAttributes(HTMLFormatter):
   def attributes(self, tag):
       for k, v in tag.attrs.items():
           yield k, v
files_from_folder = r"c:\Folder2\translated"
use_translate_folder = True
destination_language = 'vi'  #aici schimbi limba in care vrei sa traduci
extension_file = ".html"
directory = os.fsencode(files_from_folder)
def translate(text, target_language):
   url = "https://translate.google.com/translate_a/single"
   headers = {
       "Host": "translate.google.com",
       "Accept": "*/*",
       "Cookie": "",
       "User-Agent": "GoogleTranslate/5.9.59004 (iPhone; iOS 10.2; ja; iPhone9,1)",
       "Accept-Language": "fr",
       "Accept-Encoding": "gzip, deflate",
       "Connection": "keep-alive",
       }
   sentence = text
   params = {
       "client": "it",
       "dt": ["t", "rmt", "bd", "rms", "qca", "ss", "md", "ld", "ex"],
       "otf": "2",
       "dj": "1",
       "q": sentence,
       "hl": "ja",
       "ie": "UTF-8",
       "oe": "UTF-8",
       "sl": "en",
       "tl": target_language,
       }
   res = requests.get(
       url=url,
       headers=headers,
       params=params,
       )
   res = res.json()
   paragraph = ''
   for i in range(0, len(res["sentences"])):
       paragraph += res["sentences"][i]["trans"]
   return paragraph
def recursively_translate(node):
   for x in range(len(node.contents)):
       if isinstance(node.contents[x], str):
           if node.contents[x].strip() != '':
               try:
                   node.contents[x].replaceWith(translate(text=node.contents[x], target_language=destination_language))
               except:
                   pass
       elif node.contents[x] != None:
           recursively_translate(node.contents[x])
for file in os.listdir(directory):
   filename = os.fsdecode(file)
   print(filename)
   if filename == 'y_key_e479323ce281e459.html' or filename == 'directory.html': #ignore this 2 files
       continue
   if filename.endswith(extension_file):
       with open(os.path.join(files_from_folder, filename), encoding='utf-8') as html:
           soup = BeautifulSoup('<pre>' + html.read() + '</pre>', 'html.parser')
           for title in soup.findAll('title'):
               recursively_translate(title)
           for meta in soup.findAll('meta', {'name':'description'}):
               try:
                   meta['content'] = translate(text=meta['content'], target_language=destination_language)
               except:
                   pass
           for h1 in soup.findAll('h1', {'itemprop':'name'}, class_='den_articol'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(h1)) < end_comment:
                   recursively_translate(h1)
           for p in soup.findAll('p', class_='text_obisnuit'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(p)) < end_comment:
                   recursively_translate(p)
           for p in soup.findAll('p', class_='text_obisnuit2'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(p)) < end_comment:
                   recursively_translate(p)
           for span in soup.findAll('span', class_='text_obisnuit2'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(span)) < end_comment:
                   recursively_translate(span)
           for li in soup.findAll('li', class_='text_obisnuit'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(li)) < end_comment:
                   recursively_translate(li)
           for a in soup.findAll('a', class_='linkMare'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(a)) < end_comment:
                   recursively_translate(a)
           for h4 in soup.findAll('h4', class_='text_obisnuit2'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(h4)) < end_comment:
                   recursively_translate(h4)
           for h5 in soup.findAll('h5', class_='text_obisnuit2'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(h5)) < end_comment:
                   recursively_translate(h5)
           for h1 in soup.findAll('h1', {'itemprop':'name'}, class_='den_webinar'):
               begin_comment = str(soup).index('<!-- ARTICOL START -->')
               end_comment = str(soup).index('<!-- ARTICOL FINAL -->')
               if begin_comment < str(soup).index(str(h1)) < end_comment:
                   recursively_translate(h1)
       print(f'{filename} translated')
       soup = soup.encode(formatter=UnsortedAttributes()).decode('utf-8')
       new_filename = f'{filename.split(".")[0]}_{destination_language}.html'
       if use_translate_folder:
           try:
               with open(os.path.join(files_from_folder+r'\translated', new_filename), 'w', encoding='utf-8') as new_html:
                   new_html.write(soup[5:-6])
           except:
               os.mkdir(files_from_folder+r'\translated')
               with open(os.path.join(files_from_folder+r'\translated', new_filename), 'w', encoding='utf-8') as new_html:
                   new_html.write(soup[5:-6])
       else:
           with open(os.path.join(files_from_folder, new_filename), 'w', encoding='utf-8') as html:
               html.write(soup[5:-6])

That's all folks.

If you like my code, then make me a favor: translate your website into Romanian, "ro".

Sien ook hierdie weergawe 2 of VERSIE 3 of weergawe 4 of VERSIE 5 of VERSIE 6 of weergawe 7

Alatura-te Comunitatii Neculai Fantanaru
Die 63 grootste eienskappe van 'n leier
Cele 63 de calităţi ale liderului

Hoekom hierdie boek lees? Omdat dit van kritieke belang is om jou prestasie te optimaliseer. Omdat dit openbaar die hoofkoördinate daarna is bou die karakter en vaardighede van die leiers, beklemtoon wat dit belangrik is vir hulle om hul invloed te verhoog.

Leierskap - Magie van Bemeestering
Atingerea maestrului

Die wesenlike kenmerk van hierdie boek in vergelyking met ander op die mark in dieselfde domein is dat dit deur middel van voorbeelde die ideale vaardighede van 'n leier beskryf. Ek het nooit beweer dat dit maklik is om 'n goeie leier te word nie, maar as mense sal...

The Master Touch
Leadership - Magia măiestriei

Vir sommige leiers lyk "leiding" meer na 'n skaakspel, 'n spel van slimheid en deursigtigheid; vir ander beteken dit 'n kansspel, 'n speletjie wat hulle dink hulle kan wen elke keer as hulle alles op 'n enkele kaart waag en wed.

Leierskapraaisel
Leadership Puzzle

Ek het hierdie boek geskryf wat op 'n eenvoudige manier persoonlike ontwikkeling met leierskap verbind, net soos 'n legkaart, waar jy al die gegewe stukke moet pas om die algemene beeld weer saam te stel.

Prestasie in Leiding
Leadership - Pe înţelesul tuturor

Die doel van hierdie boek is om jou inligting deur middel van konkrete voorbeelde te bied en om jou te wys hoe om die vermoë te verkry om ander dinge vanuit dieselfde hoek as jy te laat sien.

Leierskap vir Dummies
Leadership - Pe înţelesul tuturor

Sonder om dit as 'n konkord te beskou, verteenwoordig die boek die probeerslag van 'n gewone man - die skrywer - wat deur eenvoudige woorde, feite en gewone voorbeelde die gewone mens moed en optimisme inboesem in sy eie strewe om sy eie baas te wees en wie weet. .. dalk selfs 'n leier.