Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.
Când lucrați cu documente, este important să puteți extrage cu ușurință conținut dintr-un anumit interval dintr-un document. Cu toate acestea, conținutul poate consta din elemente complexe, cum ar fi paragrafe, tabele, imagini etc.
Indiferent de conținutul care trebuie extras, metoda de extragere a conținutului va fi întotdeauna determinată de nodurile selectate pentru a extrage conținutul între ele. Acestea pot fi corpuri de text întregi sau rulări simple de text.
Există multe situații posibile și, prin urmare, multe tipuri diferite de noduri de luat în considerare la extragerea conținutului. De exemplu, poate doriți să extrageți conținut între:
În unele situații, poate fi necesar să combinați diferite tipuri de noduri, cum ar fi extragerea conținutului între un paragraf și un câmp sau între o rulare și un marcaj.
Acest articol oferă implementarea codului pentru extragerea textului între diferite noduri, precum și exemple de scenarii comune.
Adesea, scopul extragerii conținutului este duplicarea sau salvarea acestuia separat într-un document nou. De exemplu, puteți extrage conținut și:
Acest lucru poate fi realizat cu ușurință folosind Aspose.Words și implementarea codului de mai jos.
Codul din această secțiune abordează toate situațiile posibile descrise mai sus cu o metodă generalizată și reutilizabilă. Schița generală a acestei tehnici implică:
Pentru a extrage conținutul din documentul dvs., trebuie să apelați metoda extract_content de mai jos și să treceți parametrii corespunzători. Baza de bază a acestei metode implică găsirea nodurilor la nivel de bloc (paragrafe și tabele) și clonarea acestora pentru a crea copii identice. Dacă nodurile de marcare trecute sunt la nivel de bloc, atunci metoda este capabilă să copieze pur și simplu conținutul de la acel nivel și să-l adauge la matrice.
Cu toate acestea, dacă nodurile marker sunt inline (un copil al unui paragraf), atunci situația devine mai complexă, deoarece este necesar să se împartă paragraful la nodul inline, fie că este vorba de o rulare, câmpuri de marcaj etc. Conținutul din nodurile părinte clonate care nu sunt prezente între markeri este eliminat. Acest proces este utilizat pentru a se asigura că nodurile inline vor păstra în continuare formatarea paragrafului părinte. Metoda va rula, de asemenea, verificări asupra nodurilor trecute ca parametri și aruncă o excepție dacă oricare dintre noduri este nevalid. Parametrii care trebuie transmiși acestei metode sunt::
Implementarea metodei extract_content Puteți găsi aici. Această metodă va fi menționată în scenariile din acest articol.
De asemenea, vom defini o metodă personalizată pentru a genera cu ușurință un document din nodurile extrase. Această metodă este utilizată în multe dintre scenariile de mai jos și creează pur și simplu un document nou și importă conținutul extras în acesta.
Următorul exemplu de cod arată cum să luați o listă de noduri și să le inserați într-un document nou:
Acest lucru demonstrează modul de utilizare a metodei de mai sus pentru a extrage conținut între paragrafe specifice. În acest caz, dorim să extragem corpul scrisorii găsite în prima jumătate a documentului. Putem spune că acest lucru este între 7 Th și 11 TH paragraf.
Codul de mai jos îndeplinește această sarcină. Paragrafele corespunzătoare sunt extrase folosind metoda CompositeNode.get_child din document și trecând indicii specificați. Apoi trecem aceste noduri la metoda extract_content și afirmăm că acestea trebuie incluse în extracție. Această metodă va returna conținutul copiat între aceste noduri care sunt apoi inserate într-un document nou.
Următorul exemplu de cod arată cum să extrageți conținutul între paragrafe specifice folosind metoda extract_content de mai sus:
Putem extrage conținut între orice combinații de noduri la nivel de bloc sau inline. În acest scenariu de mai jos vom extrage conținutul dintre primul paragraf și tabelul din a doua secțiune inclusiv. Obținem nodurile markerilor apelând metoda Body.first_paragraph și CompositeNode.get_child din a doua secțiune a documentului pentru a prelua nodurile corespunzătoare Paragraph și Table. Pentru o ușoară variație, să duplicăm conținutul și să-l introducem sub original.
Următorul exemplu de cod arată cum să extrageți conținutul dintre un paragraf și un tabel folosind metoda extract_content:
Poate fi necesar să extrageți conținutul între paragrafe de același stil sau diferite, cum ar fi între paragrafe marcate cu stiluri de titlu.
Codul de mai jos arată cum se poate realiza acest lucru. Este un exemplu simplu care va extrage conținutul dintre prima instanță a stilurilor “Heading 1” și “Header 3” fără a extrage și titlurile. Pentru a face acest lucru, setăm ultimul parametru la false, care specifică faptul că nodurile marker nu ar trebui incluse.
Într-o implementare corectă, aceasta ar trebui să fie executată într-o buclă pentru a extrage conținut între toate paragrafele acestor stiluri din document. Conținutul extras este copiat într-un document nou.
Următorul exemplu de cod arată cum să extrageți conținut între paragrafe cu stiluri specifice folosind metoda extract_content:
Puteți extrage conținut între noduri inline, cum ar fi un Run, de asemenea. Rulările din diferite paragrafe pot fi transmise ca markeri. Codul de mai jos arată cum să extrageți text specific între același nod Paragraph.
Următorul exemplu de cod arată cum să extrageți conținut între anumite runde ale aceluiași paragraf folosind metoda extract_content:
Pentru a utiliza un câmp ca marker, nodul FieldStart ar trebui să fie trecut. Ultimul parametru al metodei extract_content va defini dacă întregul câmp trebuie inclus sau nu. Să extragem conținutul dintre câmpul de îmbinare “FullName " și un paragraf din document. Folosim metoda DocumentBuilder.move_to_merge_field a clasei DocumentBuilder. Aceasta va returna nodul FieldStart din numele câmpului de îmbinare transmis acestuia.
În cazul nostru, să setăm ultimul parametru trecut la metoda extract_content la False pentru a exclude câmpul din extracție. Vom reda conținutul extras la PDF.
Următorul exemplu de cod arată cum să extrageți conținut între un anumit câmp și paragraf din document folosind metoda extract_content:
Într-un document conținutul care este definit într-un marcaj este încapsulat de nodurile BookmarkStart și BookmarkEnd. Conținutul găsit între aceste două noduri alcătuiesc marcajul. Puteți trece oricare dintre aceste noduri ca orice marker, chiar și cele din marcaje diferite, atâta timp cât marcatorul de pornire apare înainte de marcatorul de încheiere din document. Vom extrage acest conținut într-un document nou folosind codul de mai jos. Opțiunea parametru isInclusive arată cum să păstrați sau să renunțați la marcaj.
Următorul exemplu de cod arată cum se extrage conținutul la care se face referire la un marcaj folosind metoda extract_content:
Un comentariu este format din nodurile CommentRangeStart, CommentRangeEnd și Comment. Toate aceste noduri sunt în linie. Primele două noduri încapsulează conținutul din document la care se face referire prin comentariu, așa cum se vede în captura de ecran de mai jos. Nodul Comment în sine este un InlineStory care poate conține paragrafe și rulează. Reprezintă mesajul comentariului văzut ca un balon de comentarii în panoul de revizuire. Deoarece acest nod este inline și descendent al unui corp, puteți extrage și conținutul din interiorul acestui mesaj.
Comentariul cuprinde titlul, primul paragraf și tabelul din a doua secțiune. Să extragem acest comentariu într-un document nou. Opțiunea isInclusive dictează dacă comentariul în sine este păstrat sau eliminat.
Următorul exemplu de cod arată cum se face acest lucru:
Modalitățile de recuperare a textului din document sunt::
Un document Word poate conține caractere de control care desemnează elemente speciale, cum ar fi câmpul, sfârșitul celulei, sfârșitul secțiunii etc. Lista completă a caracterelor posibile de control al cuvintelor este definită în clasa ControlChar. Metoda Node.get_text returnează text cu toate caracterele caracterelor de control prezente în nod.
Apelarea to_string returnează reprezentarea textului simplu a documentului numai fără caractere de control. Pentru informații suplimentare privind exportul ca text simplu, a se vedea utilizarea SaveFormat.TEXT.
Următorul exemplu de cod arată diferența dintre apelarea metodelor get_text și to_string pe un nod:
SaveFormat.TextAcest exemplu salvează documentul după cum urmează:
Următorul exemplu de cod arată cum să salvați un document în format TXT:
Poate fi necesar să extrageți imagini de document pentru a efectua unele sarcini. Aspose.Words vă permite să faceți și acest lucru.
Următorul exemplu de cod arată cum să extrageți imagini dintr-un document:
Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.