Skip to content

Latest commit

 

History

History
502 lines (403 loc) · 19.4 KB

File metadata and controls

502 lines (403 loc) · 19.4 KB
categories
Document Comparison
date 2026-03-06
description Ismerje meg, hogyan őrizheti meg a cél metaadatait a dokumentumok összehasonlítása során a GroupDocs.Comparison for .NET használatával. Lépésről lépésre útmutató C# példákkal.
keywords preserve target metadata, GroupDocs.Comparison metadata preservation, .NET document comparison, metadata preservation tutorial
lastmod 2026-03-06
linktitle Metadata Preservation Tutorial
tags
GroupDocs.Comparison
metadata-preservation
dotnet-tutorial
document-management
title Cél metaadatok megőrzése a GroupDocs.Comparison segítségével – .NET útmutató
type docs
url /hu/net/advanced-comparison/groupdocs-comparison-net-metadata-target/
weight 1

Preserve Target Metadata with GroupDocs.Comparison – .NET Tutorial

Bevezetés

Volt már, hogy két dokumentumot hasonlított össze, és közben elveszítette a fontos metaadatokat? Nem egyedül van ezzel. Amikor célmetaadatok megőrzésére van szükség a dokumentumok .NET alkalmazásban történő összehasonlítása során, a feladat trükkösnek tűnhet – de nem kell.

A GroupDocs.Comparison for .NET lehetővé teszi, hogy meghatározza, melyik dokumentum metaadatai maradjanak meg az összehasonlítás eredményében. Akár dokumentumkezelő rendszert épít, akár jogi szerződésekkel dolgozik, vagy együttműködő tartalmat kezel, mindig a megfelelő forrásdokumentum metaadataira lesz szüksége.

Ebben az útmutatóban megtanulja, hogyan őrizze meg a célmetaadatokat az összehasonlítás során, hogyan kerülje el a gyakori buktatókat, és hogyan valósítsa meg a megoldást valós helyzetekben.

Gyors válaszok

  • Mit jelent a „célmetaadatok megőrzése”? A metaadatokat (szerző, létrehozás dátuma, egyéni tulajdonságok stb.) a célként megadott dokumentumból tartja meg az összehasonlítás eredményének generálásakor.
  • Melyik GroupDocs.Comparison verzió szükséges? 25.4.0 vagy újabb verzió.
  • Használhatom .NET Core‑dal? Igen – .NET Core 2.0+ vagy .NET Framework 4.6.1+.
  • Szükséges licenc a termeléshez? A termeléshez kereskedelmi licenc szükséges; a ingyenes próba verzió tanuláshoz elegendő.
  • Működik a funkció PDF‑el és DOCX‑szel? Igen – minden főbb Office és PDF formátum támogatja a metaadatok megőrzését.

Miért fontos a metaadatok megőrzése

Mielőtt a kódba ugrunk, beszéljünk arról, miért fontos a célmetaadatok megőrzése. A dokumentum metaadatai nem csak „kellemes kiegészítések” – gyakran jogi követelmény vagy üzleti szempontból kritikusak:

  • Jogi dokumentumok – meg kell őrizni az ügyvéd‑kliens titoktartási jelzéseket.
  • Vállalati fájlok – meg kell tartani a megfelelőségi címkéket és az jóváhagyási láncokat.
  • Tudományos dolgozatok – a szerzői hozzájárulás és a verziótörténet elengedhetetlen.
  • Műszaki dokumentáció – a verziókezelés és az átnézési állapot fontos.

Megfelelő kezelés nélkül véletlenül eltávolíthatja azokat az információkat, amelyek létrehozása hónapokat vett igénybe. Itt jön jól a célmetaadatok megőrzése opció.

Előkövetelmények

Szükséges könyvtárak és verziók

  • GroupDocs.Comparison for .NET: 25.4.0 vagy újabb verzió (korábbi verziók korlátozott metaadat‑opciókkal rendelkeznek).
  • .NET Framework: 4.6.1 vagy újabb, vagy .NET Core 2.0+.

Környezet beállítása

  • Visual Studio (vagy bármely kedvelt C# IDE).
  • Alap C# ismeretek (semmi túl bonyolult, ígérem!).
  • Két minta dokumentum a teszteléshez (Word .docx nagyszerűen működik).

Tudás előkövetelmények

Nem kell GroupDocs szakértőnek lennie, de kényelmesen kell kezelnie a következőket:

  • C# using utasítások és fájlkezelés.
  • Alap dokumentumfeldolgozási koncepciók.
  • Mi is a metaadat (szerző, cím, egyéni tulajdonságok stb.).

Készen áll? Állítsuk be.

A GroupDocs.Comparison for .NET beállítása

A GroupDocs.Comparison telepítése egyszerű, de van néhány trükk, amire figyelni kell.

Telepítési lehetőségek

NuGet Package Manager Console (legkönnyebb módszer):

Install-Package GroupDocs.Comparison -Version 25.4.0

.NET CLI (ha a parancssort részesíti előnyben):

dotnet add package GroupDocs.Comparison --version 25.4.0

Pro tip: Mindig adja meg a verziót, hogy elkerülje a váratlan, a projektet megtörő változásokat.

Licenc beszerzése

Ez az a pont, ahol sok fejlesztő eleinte elakad. A GroupDocs.Comparison nem ingyenes, de vannak lehetőségek:

  • Free Trial – teljes funkcionalitás 30 napig, tökéletes értékeléshez.
  • Temporary License – meghosszabbított értékelési idő, ha több időre van szüksége.
  • Commercial License – termelési használatra (különböző árképzési szintek elérhetők).

Ne aggódjon a licencelés miatt, ha csak tanul – a próba verzió tartalmazza az összes célmetaadatok megőrzése funkciót.

Alap beállítás ellenőrzése

Győződjünk meg róla, hogy minden működik egy egyszerű teszttel:

using System.IO;
using GroupDocs.Comparison;

string sourceFilePath = "source.docx";
string targetFilePath = "target.docx";

// Initialize the Comparer object.
using (Comparer comparer = new Comparer(sourceFilePath))
{
    // Add the target document for comparison.
    comparer.Add(targetFilePath);
}

Ha ez hibák nélkül fordul, készen áll a továbblépésre. Ha nem, ellenőrizze újra a csomag telepítését és a using utasításokat.

Hogyan őrizze meg a célmetaadatokat

Most jön a fő rész – a metaadatok tényleges megőrzése a dokumentumok összehasonlítása során. Itt ragyog igazán a GroupDocs.Comparison.

A metaadatáramlás megértése

Egy tipikus összehasonlítás során:

  1. Source document – biztosítja az alap tartalmat.
  2. Target document – biztosítja a változásokat, amelyekhez összehasonlít.
  3. output document – egyesíti mindkettőt, de melyik metaadatai nyernek?

Alapértelmezés szerint a GroupDocs.Comparison a forrásdokumentum metaadatait használja. A célmetaadatok megőrzéséhez explicit módon kell jelezni az API-nak.

Lépésről‑lépésre megvalósítás

1. lépés: Inicializálja a Comparer objektumot

Ez meghatározza az „alap” dokumentumot – azt, amelyhez összehasonlít:

using (Comparer comparer = new Comparer(sourceFilePath))
{
    // All comparison operations happen within this scope
}

Miért használjon using utasításokat? Automatikusan felszabadítják az erőforrásokat, megakadályozva a memória szivárgást nagy dokumentumok feldolgozásakor. Higgyen nekem, később megköszönheti magának, amikor 50 MB-os Word fájlokkal dolgozik.

2. lépés: Adja hozzá a cél dokumentumot

Adja meg a comparernek, melyik dokumentum tartalmazza a változásokat, amelyeket elemezni szeretne:

comparer.Add(targetFilePath);

Gyakori hiba: A forrás és a cél összekeverése. Gondolja így – a forrás a „eredeti”, a cél a „frissített verzió”.

3. lépés: Állítsa be a metaadat típusát (itt történik a varázslat)

Adja meg, melyik dokumentum metaadatai maradjanak meg a kimenetben:

comparer.Compare(outputFileName, new SaveOptions() { CloneMetadataType = MetadataType.Target });

Mi történik? A CloneMetadataType = MetadataType.Target azt mondja a GroupDocs.Comparison‑nek: „Hé, a végső eredményben a cél dokumentum metaadatait akarom megtartani.”

Teljes működő példa

Itt van minden egyben egy futtatható programban:

using System;
using System.IO;
using GroupDocs.Comparison;
using GroupDocs.Comparison.Options;

class Program
{
    static void Main(string[] args)
    {
        try
        {
            string sourceFile = "original_document.docx";
            string targetFile = "updated_document.docx";
            string outputFile = "comparison_result.docx";
            
            using (Comparer comparer = new Comparer(sourceFile))
            {
                comparer.Add(targetFile);
                
                // Preserve target document metadata
                comparer.Compare(outputFile, new SaveOptions() 
                { 
                    CloneMetadataType = MetadataType.Target 
                });
                
                Console.WriteLine($"Comparison completed! Check {outputFile}");
            }
        }
        catch (Exception ex)
        {
            Console.WriteLine($"Error during comparison: {ex.Message}");
        }
    }
}

Kerülendő gyakori buktatók

  • Fájlútvonal problémák – mindig használjon teljes elérési utat, vagy győződjön meg róla, hogy a fájlok a munkakönyvtárban vannak:
// Good
string sourceFile = Path.Combine(Directory.GetCurrentDirectory(), "docs", "source.docx");

// Risky (might work locally but fail in production)
string sourceFile = "source.docx";
  • Memória kezelés – nagy dokumentumok esetén mindig csomagolja a Comparer objektumokat using utasításokba.

  • Verzió kompatibilitás – a különböző GroupDocs.Comparison kiadások különböző metaadat‑opciókat kínálnak – a legjobb eredményért maradjon a 25.4.0 vagy újabb verziónál.

Haladó metaadat szcenáriók

Mikor használjon cél- vagy forrásmetaadatot

Szituáció Target metaadat előnyben részesítése Source metaadat előnyben részesítése
Frissített szerzői információ szükséges
Az eredeti dokumentumnak jogi precedenciája van
Egyéni tulajdonságok csak az újabb fájlban vannak
A “mester” dokumentum történetét szeretné megtartani

Több cél dokumentum kezelése

Több cél dokumentummal is összehasonlíthat, miközben a hozzáadott első cél metaadatait őrzi meg:

using (Comparer comparer = new Comparer(sourceFilePath))
{
    comparer.Add(targetFilePath1);
    comparer.Add(targetFilePath2);
    comparer.Add(targetFilePath3);
    
    // Metadata will come from the first target document
    comparer.Compare(outputFileName, new SaveOptions() 
    { 
        CloneMetadataType = MetadataType.Target 
    });
}

Gyakorlati alkalmazások és felhasználási esetek

Jogi dokumentumkezelés

A jogi irodáknak gyakran kell összehasonlítani a szerződés verziókat, miközben megőrzik a specifikus metaadat jelzőket:

// Preserve client metadata from updated contract
using (Comparer comparer = new Comparer("original_contract.docx"))
{
    comparer.Add("client_revised_contract.docx");
    
    comparer.Compare("final_contract_comparison.docx", new SaveOptions() 
    { 
        CloneMetadataType = MetadataType.Target  // Keep client's metadata
    });
}

Tudományos és kutatási együttműködés

Több kutató együttműködésénél a legfrissebb szerzői információk megőrzése a cél:

// Keep metadata from the researcher's latest submission
using (Comparer comparer = new Comparer("draft_paper.docx"))
{
    comparer.Add("researcher_updates.docx");
    
    comparer.Compare("paper_comparison.docx", new SaveOptions() 
    { 
        CloneMetadataType = MetadataType.Target  // Preserve researcher metadata
    });
}

Vállalati megfelelőségi munkafolyamatok

Szabályozott iparágakban a megfelelőségi metaadatok fenntartása kritikus:

// Preserve compliance tags from updated policy document
using (Comparer comparer = new Comparer("old_policy.docx"))
{
    comparer.Add("compliance_approved_policy.docx");
    
    comparer.Compare("policy_comparison.docx", new SaveOptions() 
    { 
        CloneMetadataType = MetadataType.Target  // Keep compliance metadata
    });
}

Gyakori problémák hibaelhárítása

„File Not Found” hibák

A leggyakoribb probléma. Hibakeresés explicit ellenőrzésekkel:

string sourceFile = "source.docx";

// Always check if files exist before comparison
if (!File.Exists(sourceFile))
{
    Console.WriteLine($"Source file not found: {Path.GetFullPath(sourceFile)}");
    return;
}

// Same for target files
if (!File.Exists(targetFile))
{
    Console.WriteLine($"Target file not found: {Path.GetFullPath(targetFile)}");
    return;
}

Memória problémák nagy dokumentumoknál

10 MB‑nél nagyobb dokumentumok esetén fontolja meg ezeket az optimalizációkat:

// Use explicit disposal for large documents
using (var comparer = new Comparer(sourceFile))
{
    comparer.Add(targetFile);
    
    var saveOptions = new SaveOptions() 
    { 
        CloneMetadataType = MetadataType.Target 
    };
    
    comparer.Compare(outputFile, saveOptions);
    
    // Explicitly clean up
    GC.Collect();
    GC.WaitForPendingFinalizers();
}

Jogosultsági és hozzáférési problémák

Védett fájlok vagy hálózati megosztások esetén:

try
{
    using (var comparer = new Comparer(sourceFile))
    {
        comparer.Add(targetFile);
        comparer.Compare(outputFile, new SaveOptions() 
        { 
            CloneMetadataType = MetadataType.Target 
        });
    }
}
catch (UnauthorizedAccessException ex)
{
    Console.WriteLine("Access denied. Check file permissions.");
    Console.WriteLine($"Details: {ex.Message}");
}
catch (IOException ex)
{
    Console.WriteLine("File I/O error occurred.");
    Console.WriteLine($"Details: {ex.Message}");
}

Teljesítmény szempontok és bevált gyakorlatok

Memória kezelés

A GroupDocs.Comparison memóriaigényes lehet. Használjon using utasításokat a felszabadítás garantálásához:

// Good - automatic resource cleanup
using (var comparer = new Comparer(sourceFile))
{
    // comparison logic here
}

// Bad - potential memory leaks
var comparer = new Comparer(sourceFile);
// ... comparison logic
// comparer.Dispose(); // Easy to forget!

Dokumentumok feldolgozása kötegekben – ha sok fájlt hasonlít össze, kezelje őket kisebb csoportokban a memóriahasználat alacsonyan tartásához.

Aszinkron műveletek a jobb válaszkészségért

Asztali vagy webalkalmazásoknál csomagolja az összehasonlítást aszinkron metódusba:

public async Task<bool> CompareDocumentsAsync(string source, string target, string output)
{
    return await Task.Run(() =>
    {
        try
        {
            using (var comparer = new Comparer(source))
            {
                comparer.Add(target);
                comparer.Compare(output, new SaveOptions() 
                { 
                    CloneMetadataType = MetadataType.Target 
                });
                return true;
            }
        }
        catch
        {
            return false;
        }
    });
}

Fájlméret irányelvek

  • Kicsi (< 1 MB) – közvetlenül feldolgozni.
  • Közepes (1‑10 MB) – mutassa a folyamatot a UI válaszkészségének fenntartásához.
  • Nagy (> 10 MB) – mindig használjon aszinkron feldolgozást, és fontolja meg a fenti módon explicit GC‑t.

Integráció nagyobb rendszerekkel

ASP.NET Core integráció

Az alábbi egy kész‑használatra szánt vezérlő, amely két feltöltött fájlt fogad, végrehajtja az összehasonlítást, és visszaadja az eredményt, miközben megőrzi a célmetaadatokat:

[ApiController]
[Route("api/[controller]")]
public class DocumentComparisonController : ControllerBase
{
    [HttpPost("compare-with-target-metadata")]
    public async Task<IActionResult> CompareWithTargetMetadata(
        IFormFile sourceFile, 
        IFormFile targetFile)
    {
        var tempSource = Path.GetTempFileName();
        var tempTarget = Path.GetTempFileName();
        var outputPath = Path.GetTempFileName();
        
        try
        {
            // Save uploaded files temporarily
            await sourceFile.CopyToAsync(new FileStream(tempSource, FileMode.Create));
            await targetFile.CopyToAsync(new FileStream(tempTarget, FileMode.Create));
            
            // Perform comparison with target metadata preservation
            using (var comparer = new Comparer(tempSource))
            {
                comparer.Add(tempTarget);
                comparer.Compare(outputPath, new SaveOptions() 
                { 
                    CloneMetadataType = MetadataType.Target 
                });
            }
            
            // Return comparison result
            var resultBytes = await System.IO.File.ReadAllBytesAsync(outputPath);
            return File(resultBytes, "application/vnd.openxmlformats-officedocument.wordprocessingml.document", 
                       "comparison_result.docx");
        }
        finally
        {
            // Clean up temporary files
            if (System.IO.File.Exists(tempSource)) System.IO.File.Delete(tempSource);
            if (System.IO.File.Exists(tempTarget)) System.IO.File.Delete(tempTarget);
            if (System.IO.File.Exists(outputPath)) System.IO.File.Delete(outputPath);
        }
    }
}

Gyakran ismételt kérdések

Q: Megőrizhetem a metaadatokat több cél dokumentumból az összehasonlítás során?
A: Ha több cél fájlt ad hozzá, a GroupDocs.Comparison a első hozzáadott cél dokumentum metaadatait használja. Tegye először a láncba azt a dokumentumot, amelynek metaadatait meg szeretné tartani.

Q: Mi történik, ha a cél dokumentum nem tartalmaz bizonyos metaadat mezőket?
A: Csak a célban létező metaadatok kerülnek átmásolásra a kimenetbe. A hiányzó mezők egyszerűen kihagyásra kerülnek; az összehasonlítás továbbra is sikeres.

Q: Hogyan kezeljem a jelszóval védett dokumentumokat?
A: Használjon egy LoadOptions objektumot a jelszóval, majd adja át a Comparer konstruktorának:

var loadOptions = new LoadOptions() { Password = "your_password" };
using (var comparer = new Comparer(sourceFile, loadOptions))
{
    // comparison logic here
}

Q: Van mód csak kiválasztott metaadat tulajdonságok megőrzésére?
A: A jelenlegi API a kiválasztott forrás (Target vagy Source) összes metaadatát megőrzi. Finomabb vezérléshez a metaadatokat az összehasonlítás után kell kinyerni és manuálisan újra alkalmazni.

Q: Mely dokumentumformátumok támogatják a metaadatok megőrzését?
A: A leggyakoribb üzleti formátumok – DOCX, PDF, PPTX, XLSX és sok más – támogatják a metaadatok megőrzését. A teljes listáért tekintse meg a hivatalos dokumentációt.

Q: Hol kaphatok segítséget, ha problémába ütközöm?
A: Látogassa meg a GroupDocs támogatási fórum közösségi segítségért, vagy vegye fel a kapcsolatot a GroupDocs támogatással közvetlenül, ha kereskedelmi licencet használ.

További források


Utolsó frissítés: 2026-03-06
Tesztelve: GroupDocs.Comparison 25.4.0 for .NET
Szerző: GroupDocs