Jak debugować OCR w C

This article was translated from English: Does it need improvement?
Translated
View the article in English

IronOCR umożliwia wykrywanie błędów OCR u źródła, ocenę jakości rozpoznawania na poziomie słów i znaków oraz monitorowanie długotrwałych zadań w czasie rzeczywistym. Wbudowane narzędzia, takie jak rejestrowanie plików diagnostycznych, typowana hierarchia wyjątków, ocena pewności dla poszczególnych wyników oraz zdarzenie OcrProgress, wspierają te procesy w potokach produkcyjnych.

W niniejszym przewodniku omówiono praktyczne przykłady dla każdego z nich: włączanie rejestrowania diagnostycznego, obsługa wyjątków typowanych, sprawdzanie poprawności wyników za pomocą wskaźników pewności, monitorowanie postępu zadań w czasie rzeczywistym oraz izolowanie błędów w potokach przetwarzania wsadowego.

Szybki start: Włącz pełne logowanie diagnostyczne OCR

Ustaw LogFilePath i LoggingTryb w klasie Installation przed pierwszym wywołaniem Read. Wystarczą dwie właściwości, aby zapisać w pliku dziennika informacje o inicjalizacji Tesseract, ładowaniu pakietu językowego oraz szczegółach przetwarzania.

  1. Install IronOCR with NuGet Package Manager

    PM > Install-Package IronOcr
  2. Skopiuj i uruchom ten fragment kodu.

    IronOcr.Installation.LogFilePath = "ocr.log"; IronOcr.Installation.LoggingTryb = IronOcr.Installation.LoggingModes.All;
  3. Wdrożenie do testowania w środowisku produkcyjnym

    Rozpocznij używanie IronOCR w swoim projekcie już dziś z darmową wersją próbną

    arrow pointer


Jak włączyć rejestrowanie diagnostyczne?

Klasa Installation udostępnia trzy elementy sterujące rejestrowaniem. Ustaw te parametry przed wywołaniem dowolnej metody Read.

:path=/static-assets/ocr/content-code-examples/how-to/debugging-enable-logging.cs
using IronOcr;

// Write logs to a specific file
Installation.LogFilePath = "logs/ocr_diagnostics.log";

// Enable all logging channels: file + debug output
Installation.LoggingMode = Installation.LoggingModes.All;

// Or pipe logs into your existing ILogger pipeline
Installation.CustomLogger = myLoggerInstance;
Imports IronOcr

' Write logs to a specific file
Installation.LogFilePath = "logs/ocr_diagnostics.log"

' Enable all logging channels: file + debug output
Installation.LoggingMode = Installation.LoggingModes.All

' Or pipe logs into your existing ILogger pipeline
Installation.CustomLogger = myLoggerInstance
$vbLabelText   $csharpLabel

LoggingTryb akceptuje wartości flag z wyliczenia LoggingTrybs:

Tabela 1: Opcje trybów logowania
TrybWynik docelowyPrzykład zastosowania
BrakWyłączoneProdukcja z zewnętrznym monitoringiem
DebugowanieOkno wyjściowe debugowania IDELokalny rozwój
PlikLogFilePathGromadzenie logów po stronie serwera
WszystkieDebug + PlikPełny zrzut diagnostyczny

Właściwość CustomLogger obsługuje dowolną implementację Microsoft.Extensions.Logging.ILogger, umożliwiając kierowanie diagnostyką OCR do Serilog, NLog lub innych strukturalnych odbiorników logów w Twoim potoku. Użyj ClearLogFiles, aby usunąć zgromadzone dane logów między uruchomieniami.

Po skonfigurowaniu logowania następnym krokiem jest zrozumienie, jakie wyjątki może zgłaszać IronOCR i jak sobie z nimi radzić.

Jakie wyjątki generuje IronOCR?

IronOCR definiuje wyjątki typowane w przestrzeni nazw IronOcr.Exceptions. Wykrywanie tych konkretnych błędów, zamiast stosowania ogólnego bloku przechwytującego, pozwala skierować każdy typ błędu do właściwej ścieżki naprawy.

Tabela 2: Odnośniki do wyjątków IronOCR
WyjątekTypowa przyczynaRozwiązanie
IronOcrInputWyjątekUszkodzony lub nieobsługiwany obraz/PDFZweryfikuj plik przed załadowaniem do OcrInput
IronOcrProductWyjątekBłąd silnika wewnętrznego podczas wykonywania OCRWłącz rejestrowanie, sprawdź wynik logu, zaktualizuj do najnowszej wersji NuGet
IronOcrDictionaryWyjątekBrakuje lub jest uszkodzony plik językowy .traineddataPonownie zainstaluj pakiet językowy NuGet lub ustaw LanguagePackDirectory
IronOcrNativeWyjątekBłąd interoperacyjności C++Zainstaluj Visual C++ Redistributable; sprawdź wsparcie AVX
IronOcrLicensingWyjątekBrakujący lub wygasły klucz licencyjnyUstaw LicenseKey przed wywołaniem Read
LanguagePackWyjątekNie znaleziono pakietu językowego pod oczekiwaną ścieżkąZweryfikuj LanguagePackDirectory lub ponownie zainstaluj pakiet językowy NuGet
IronOcrAssemblyVersionMismatchWyjątekNiedopasowane wersje zestawów po częściowej aktualizacjiWyczyść pamięć podręczną NuGet, przywróć pakiety, upewnij się, że wszystkie pakiety IronOCR są zgodne

Użyj poniższego bloku try-catch, aby obsłużyć każdy typ wyjątku osobno, stosując filtry wyjątków dla warunkówego logowania.

Dane wejściowe

Jednostronicowa faktura dostawcy od IronOCR Solutions dla Acme Corporation, załadowana poprzez LoadPdf do OcrInput. Zawiera cztery pozycje na linii, podatek i łączną sumę — wystarczająco różnorodność tekstu, aby każdy obsługujący wyjątki miał realistyczne ćwiczenie.

invoice_scan.pdf: Faktura dostawcy (#INV-2024-7829) używana do demonstrowania każdego typowanego obsługującego wyjątków po kolei.

:path=/static-assets/ocr/content-code-examples/how-to/debugging-exception-handling.cs
using IronOcr;
using IronOcr.Exceptions;

var ocr = new IronTesseract();

try
{
    using var input = new OcrInput();
    input.LoadPdf("invoice_scan.pdf");

    OcrResult result = ocr.Read(input);
    Console.WriteLine($"Text: {result.Text}");
    Console.WriteLine($"Confidence: {result.Confidence:P1}");
}
catch (IronOcrInputException ex)
{
    // File could not be loaded — corrupt, locked, or unsupported format
    Console.Error.WriteLine($"Input error: {ex.Message}");
}
catch (IronOcrDictionaryException ex)
{
    // Language pack missing — common in containerized deployments
    Console.Error.WriteLine($"Language pack error: {ex.Message}");
}
catch (IronOcrNativeException ex) when (ex.Message.Contains("AVX"))
{
    // CPU does not support AVX instructions
    Console.Error.WriteLine($"Hardware incompatibility: {ex.Message}");
}
catch (IronOcrLicensingException)
{
    Console.Error.WriteLine("License key is missing or invalid.");
}
catch (IronOcrProductException ex)
{
    // Catch-all for other IronOCR engine errors
    Console.Error.WriteLine($"OCR engine error: {ex.Message}");
    Console.Error.WriteLine($"Stack trace: {ex.StackTrace}");
}
Imports IronOcr
Imports IronOcr.Exceptions

Dim ocr As New IronTesseract()

Try
    Using input As New OcrInput()
        input.LoadPdf("invoice_scan.pdf")

        Dim result As OcrResult = ocr.Read(input)
        Console.WriteLine($"Text: {result.Text}")
        Console.WriteLine($"Confidence: {result.Confidence:P1}")
    End Using
Catch ex As IronOcrInputException
    ' File could not be loaded — corrupt, locked, or unsupported format
    Console.Error.WriteLine($"Input error: {ex.Message}")
Catch ex As IronOcrDictionaryException
    ' Language pack missing — common in containerized deployments
    Console.Error.WriteLine($"Language pack error: {ex.Message}")
Catch ex As IronOcrNativeException When ex.Message.Contains("AVX")
    ' CPU does not support AVX instructions
    Console.Error.WriteLine($"Hardware incompatibility: {ex.Message}")
Catch ex As IronOcrLicensingException
    Console.Error.WriteLine("License key is missing or invalid.")
Catch ex As IronOcrProductException
    ' Catch-all for other IronOCR engine errors
    Console.Error.WriteLine($"OCR engine error: {ex.Message}")
    Console.Error.WriteLine($"Stack trace: {ex.StackTrace}")
End Try
$vbLabelText   $csharpLabel

Wynik

Wynik końcowy

Faktura wczytuje się czysto, a silnik zwraca liczbę znaków razem z wynikiem zaufania.

Wyjście terminala pokazujące udane odczytanie OCR invoice_scan.pdf z liczbą znaków i wynikiem zaufania

Niepomyślne wyjście

Wyjście terminala pokazujące wyjątek rzucony podczas ładowania brakującego pliku PDF

Uporządkuj bloki catch od najbardziej specyficznego do najbardziej ogólnego. Klauzula when na filtrach IronOcrNativeWyjątek wykrywa awarie związane z AVX, nie wychwytując niepowiązanych błędów natywnych. Każdy obsługujący loguje komunikat o wyjątku; blok catch-all również przechwytuje ślad stosu do analizy post-mortem.

Złapanie właściwego wyjątku powie ci, że coś poszło nie tak, ale nie jak dobrze silnik działał, gdy się udało. Do tego użyj wyników zaufania.

Jak zweryfikować wynik OCR za pomocą wyników zaufania?

Każdy OcrResult udostępnia właściwość Confidence, której wartość z zakresu od 0 do 1 reprezentuje średnią pewność statystyczną silnika dla wszystkich rozpoznanych znaków. Możesz uzyskać do tego dostęp na każdym poziomie hierarchii wyników: dokument, strona, akapit, słowo i znak.

Użyj wzorca bramkowanego progu, aby zapobiec propagowaniu się wyników niskiej jakości w dół strumienia.

Dane wejściowe

Paragon termiczny z wyszczególnionymi pozycjami, rabatami, sumami i BARCODE, załadowany za pomocą LoadImage. Jego wąska szerokość, monospace font i błądy druk czynią go praktycznym stresstestem dla progów zaufania dla każdego słowa.

Przykładowy termiczny paragon z FoodMart z pokazaniem zakupów z podziałem pozycji, sum i punktów nagrody używany jako wejście OCR

receipt.png: Skany paragonów termicznych używane do demonstrowania walidacji pewności progowej i szczegółowego przełamania dokładności na słowo dla obrazu paragonu.

:path=/static-assets/ocr/content-code-examples/how-to/debugging-confidence-scoring.cs
using IronOcr;

var ocr = new IronTesseract();
using var input = new OcrInput();
input.LoadImage("receipt.png");

OcrResult result = ocr.Read(input);
double confidence = result.Confidence;

Console.WriteLine($"Overall confidence: {confidence:P1}");

// Threshold-gated decision
if (confidence >= 0.90)
{
    Console.WriteLine("ACCEPT — high confidence, processing result.");
    ProcessResult(result.Text);
}
else if (confidence >= 0.70)
{
    Console.WriteLine("FLAG — moderate confidence, queuing for review.");
    QueueForReview(result.Text, confidence);
}
else
{
    Console.WriteLine("REJECT — low confidence, logging for investigation.");
    LogRejection("receipt.png", confidence);
}

// Drill into per-page and per-word confidence for diagnostics
foreach (var page in result.Pages)
{
    Console.WriteLine($"  Page {page.PageNumber}: {page.Confidence:P1}");

    var lowConfidenceWords = page.Words
        .Where(w => w.Confidence < 0.70)
        .ToList();

    foreach (var word in lowConfidenceWords)
    {
        Console.WriteLine($"    Low-confidence word: \"{word.Text}\" ({word.Confidence:P1})");
    }
}
Imports IronOcr

Dim ocr As New IronTesseract()
Using input As New OcrInput()
    input.LoadImage("receipt.png")

    Dim result As OcrResult = ocr.Read(input)
    Dim confidence As Double = result.Confidence

    Console.WriteLine($"Overall confidence: {confidence:P1}")

    ' Threshold-gated decision
    If confidence >= 0.9 Then
        Console.WriteLine("ACCEPT — high confidence, processing result.")
        ProcessResult(result.Text)
    ElseIf confidence >= 0.7 Then
        Console.WriteLine("FLAG — moderate confidence, queuing for review.")
        QueueForReview(result.Text, confidence)
    Else
        Console.WriteLine("REJECT — low confidence, logging for investigation.")
        LogRejection("receipt.png", confidence)
    End If

    ' Drill into per-page and per-word confidence for diagnostics
    For Each page In result.Pages
        Console.WriteLine($"  Page {page.PageNumber}: {page.Confidence:P1}")

        Dim lowConfidenceWords = page.Words _
            .Where(Function(w) w.Confidence < 0.7) _
            .ToList()

        For Each word In lowConfidenceWords
            Console.WriteLine($"    Low-confidence word: ""{word.Text}"" ({word.Confidence:P1})")
        Next
    Next
End Using
$vbLabelText   $csharpLabel

Wynik

Wyjście terminala pokazujące wynik zaufania, decyzję akceptacji/flagi/odrzucenia i dogłębną dokładność dla każdego słowa w przypadku obrazu paragonu

Ten wzorzec jest niezbędny w liniach, gdzie OCR wchodzi do wprowadzania danych, przetwarzania faktur lub przepływów pracy zgodności. Dogłębna analiza dla każdego słowa identyfikuje dokładnie, które obszary źródłowego obrazu powodowały degradację; możesz potem zastosować filtry jakości obrazu lub korekcje orientacji i ponownie przetworzyć. Aby uzyskać głębsze spojrzenie na wyniki zaufania, zobacz poziomy zaufania how-to.

Dla zadań długotrwałych, sam wynik zaufania nie wystarcza. Musisz również wiedzieć, czy silnik nadal się rozwija, i tu właśnie pojawia się zdarzenie OcrProgress.

Jak monitorować postęp OCR w czasie rzeczywistym?

W przypadku dokumentów wielostronicowych zdarzenie OcrProgress na IronTesseract uruchamia się po zakończeniu każdej strony. Obiekt OcrProgressEventArgs udostępnia procentowy postęp, upływający czas, całkowitą liczbę stron oraz liczbę ukończonych stron. Przykład używa tego trzystronicowego raportu kwartalnego jako wejścia: strukturalnego dokumentu biznesowego obejmującego sprawozdanie z zarządzania, rozbicie przychodów i metryki operacyjne.

Dane wejściowe

Trzy stronicowy raport finansowy za pierwszy kwartał 2024 r. załadowany za pośrednictwem LoadPdf. Strona pierwsza obejmuje sprawozdanie z zarządzania z metrykami KPI, strona druga zawiera tabele przychodów według linii produktówej i regionu, a strona trzecia obejmuje wolumeny przetwarzania operacyjnego — każdy typ strony wytworzy różne czasy realizacji, które można zaobserwować w wywołaniach zwrotnych postępu.

quarterly_report.pdf: Three-page Q1 2024 financial report (executive summary, revenue breakdown, operational metrics) used to demonstrate real-time `OcrProgress` callbacks per page.

:path=/static-assets/ocr/content-code-examples/how-to/debugging-progress-monitoring.cs
using IronOcr;

var ocr = new IronTesseract();

ocr.OcrProgress += (sender, e) =>
{
    Console.WriteLine(
        $"[OCR] {e.ProgressPercent}% complete | " +
        $"Page {e.PagesComplete}/{e.TotalPages} | " +
        $"Elapsed: {e.Duration.TotalSeconds:F1}s"
    );
};

using var input = new OcrInput();
input.LoadPdf("quarterly_report.pdf");

OcrResult result = ocr.Read(input);
Console.WriteLine($"Finished in {result.Pages.Count()} pages, confidence: {result.Confidence:P1}");
Imports IronOcr

Dim ocr = New IronTesseract()

AddHandler ocr.OcrProgress, Sub(sender, e)
    Console.WriteLine(
        $"[OCR] {e.ProgressPercent}% complete | " &
        $"Page {e.PagesComplete}/{e.TotalPages} | " &
        $"Elapsed: {e.Duration.TotalSeconds:F1}s"
    )
End Sub

Using input As New OcrInput()
    input.LoadPdf("quarterly_report.pdf")

    Dim result As OcrResult = ocr.Read(input)
    Console.WriteLine($"Finished in {result.Pages.Count()} pages, confidence: {result.Confidence:P1}")
End Using
$vbLabelText   $csharpLabel

Wynik

Wyjście terminala pokazujące wywołania zwrotne wydarzeń OcrProgress na stronę z procentem ukończenia i upływem czasu dla trzystronicowego PDF

Podłącz to wydarzenie do swojej infrastruktury logującej, aby śledzić czas trwania zadania OCR i wykrywać zacięcia. Jeśli czas upływu przekroczy próg bez postępu procentu postępu, linia może oznaczyć zadanie do zbadania. To jest szczególnie przydatne dla przetwarzania wsadowego PDF, gdzie jedna błędna strona może zablokować całe zadanie.

Monitorowanie postępu pokazuje stan wykonania, ale błąd na poziomie pliku nadal może zatrzymać całą partię, jeśli nie jest izolowany.

Jak obsługiwać błędy w przepływach wsadowych OCR?

W produkcji, jedna awaria pliku nie powinna zatrzymywać całej partii. Izoluj błędy dla każdego pliku, loguj awarie z kontekstem i twórz raport podsumowujący na końcu. Przykład przetwarza katalog dokumentów skanowania zawierający fakturę, zamówienie zakupu, umowę serwisową oraz jeden świadomie uszkodzony plik w celu wywołania ścieżki błędów. Poniżej pokazano reprezentatywną próbkę:

Dane wejściowe

Folder plików PDF przekazany do Directory.GetFiles — faktura, zamówienie, umowa o świadczenie usług oraz jeden celowo uszkodzony plik. Dwa reprezentatywne przykłady poniżej pokazują różnorodność dokumentów przetwarzanych przez potok w jednym przebiegu.

:path=/static-assets/ocr/content-code-examples/how-to/debugging-batch-pipeline.cs
using IronOcr;
using IronOcr.Exceptions;

var ocr = new IronTesseract();
Installation.LogFilePath = "batch_debug.log";
Installation.LoggingMode = Installation.LoggingModes.File;

string[] files = Directory.GetFiles("scans/", "*.pdf");
int succeeded = 0, failed = 0;
double totalConfidence = 0;
var failures = new List<(string File, string Error)>();

foreach (string file in files)
{
    try
    {
        using var input = new OcrInput();
        input.LoadPdf(file);

        OcrResult result = ocr.Read(input);
        totalConfidence += result.Confidence;
        succeeded++;

        Console.WriteLine($"OK: {Path.GetFileName(file)} — {result.Confidence:P1}");
    }
    catch (IronOcrInputException ex)
    {
        failed++;
        failures.Add((file, $"Input error: {ex.Message}"));
        Console.Error.WriteLine($"FAIL: {Path.GetFileName(file)} — {ex.Message}");
    }
    catch (IronOcrProductException ex)
    {
        failed++;
        failures.Add((file, $"Engine error: {ex.Message}"));
        Console.Error.WriteLine($"FAIL: {Path.GetFileName(file)} — {ex.Message}");
    }
    catch (Exception ex)
    {
        failed++;
        failures.Add((file, $"Unexpected: {ex.Message}"));
        Console.Error.WriteLine($"FAIL: {Path.GetFileName(file)} — {ex.GetType().Name}: {ex.Message}");
    }
}

// Summary report
Console.WriteLine($"\n--- Batch Summary ---");
Console.WriteLine($"Total: {files.Length} | Passed: {succeeded} | Failed: {failed}");
if (succeeded > 0)
    Console.WriteLine($"Average confidence: {totalConfidence / succeeded:P1}");

foreach (var (f, err) in failures)
    Console.WriteLine($"  {Path.GetFileName(f)}: {err}");
Imports IronOcr
Imports IronOcr.Exceptions
Imports System.IO

Dim ocr As New IronTesseract()
Installation.LogFilePath = "batch_debug.log"
Installation.LoggingMode = Installation.LoggingModes.File

Dim files As String() = Directory.GetFiles("scans/", "*.pdf")
Dim succeeded As Integer = 0
Dim failed As Integer = 0
Dim totalConfidence As Double = 0
Dim failures As New List(Of (File As String, Error As String))()

For Each file As String In files
    Try
        Using input As New OcrInput()
            input.LoadPdf(file)

            Dim result As OcrResult = ocr.Read(input)
            totalConfidence += result.Confidence
            succeeded += 1

            Console.WriteLine($"OK: {Path.GetFileName(file)} — {result.Confidence:P1}")
        End Using
    Catch ex As IronOcrInputException
        failed += 1
        failures.Add((file, $"Input error: {ex.Message}"))
        Console.Error.WriteLine($"FAIL: {Path.GetFileName(file)} — {ex.Message}")
    Catch ex As IronOcrProductException
        failed += 1
        failures.Add((file, $"Engine error: {ex.Message}"))
        Console.Error.WriteLine($"FAIL: {Path.GetFileName(file)} — {ex.Message}")
    Catch ex As Exception
        failed += 1
        failures.Add((file, $"Unexpected: {ex.Message}"))
        Console.Error.WriteLine($"FAIL: {Path.GetFileName(file)} — {ex.GetType().Name}: {ex.Message}")
    End Try
Next

' Summary report
Console.WriteLine(vbCrLf & "--- Batch Summary ---")
Console.WriteLine($"Total: {files.Length} | Passed: {succeeded} | Failed: {failed}")
If succeeded > 0 Then
    Console.WriteLine($"Average confidence: {totalConfidence / succeeded:P1}")
End If

For Each failure In failures
    Console.WriteLine($"  {Path.GetFileName(failure.File)}: {failure.Error}")
Next
$vbLabelText   $csharpLabel

Wynik

Wyjście terminala pokazujące wyniki lini wsadowej z licznikami znaków dla każdego pliku, wynikami zaufania, jednym błędem z uszkodzonego PDF i linia podsumowania

Zewnętrzny blok catch obsługuje nieprzewidziane błędy, w tym limity czasu sieci na współdzielonej pamięci, problemy z uprawnieniami lub stany brak pamięci na dużych TIFFach. Każda awaria rejestruje ścieżkę pliku i komunikat o błędzie do podsumowania, podczas gdy pętla kontynuuje przetwarzanie pozostałych plików. Plik dziennika w batch_debug.log zawiera szczegółowe informacje na poziomie silnika dla każdego pliku, który uruchamia wewnętrzną diagnostykę.

W celu zapewnienia wykonywania bez blokowania w usługach lub aplikacjach internetowych, IronOCR obsługuje ReadAsync, które wykorzystuje tę samą strukturę try-catch.

Jeśli linia działa bez błędów, ale wyodrębniony tekst jest nadal niepoprawny, przyczyna leży prawie zawsze po stronie jakości obrazu, a nie kodu. Oto jak się do tego zabrać.

Jak debugować dokładność OCR?

Jeśli wyniki zaufania są konsekwentnie niskie, problemem jest źródłowy obraz, a nie silnik OCR. IronOCR zapewnia narzędzia do przedprzetwarzania, aby to rozwiązać:

Dla problemów specyficznych dla wdrożenia, IronOCR utrzymuje dedykowane przewodniki do rozwiązywania problemów dla Azure Functions, Docker i Linux oraz ogólnej konfiguracji środowiska.

Gdzie powinienem się udać dalej?

Teraz, gdy zrozumiałeś, jak debugować IronOCR w czasie wykonania, odkryj:

Dla zastosowania w produkcji, pamiętaj, aby uzyskać licencję, aby usunąć znaki wodne i mieć pełen dostęp do funkcjonalności.

Często Zadawane Pytania

Jakie są najczęstsze problemy podczas debugowania OCR w C#?

Częste problemy obejmują nieprawidłowe wyniki OCR, niskie oceny pewności i nieoczekiwane wyjątki. IronOCR dostarcza narzędzia, takie jak logowanie i ocenianie pewności, które pomagają identyfikować i rozwiązywać te problemy.

Jak IronOCR wspomaga obsługę błędów w C#?

IronOCR oferuje typowane wyjątki i szczegółowe komunikaty o błędach, które pomagają w zrozumieniu i skutecznej obsłudze błędów podczas operacji OCR w aplikacjach C#.

Jakie funkcje logowania oferuje IronOCR do debugowania?

IronOCR zawiera wbudowane funkcje logowania, które pomagają śledzić procesy OCR i identyfikować potencjalne problemy poprzez rejestrowanie szczegółowych informacji o operacjach OCR.

Jak ocenianie pewności może poprawić wyniki OCR?

Ocenianie pewności w IronOCR pomaga określić dokładność rozpoznanego tekstu, umożliwiając programistom skupienie się na obszarach o niskiej pewności i poprawienie wyników OCR.

Czy mogę śledzić postęp zadań OCR używając IronOCR?

Tak, IronOCR zapewnia funkcje śledzenia postępu, które umożliwiają programistom monitorowanie stanu i trwania zadań OCR, co ułatwia zarządzanie zasobami i optymalizację wydajności.

Jakie wzorce try-catch są zalecane do obsługi błędów OCR?

IronOCR sugeruje użycie wzorców try-catch gotowych do produkcji, aby łagodnie obsługiwać wyjątki, zapewniając, że aplikacje OCR pozostaną solidne i łatwe w utrzymaniu.

Jak wbudowane narzędzia IronOCR mogą ulepszyć debugowanie OCR?

Narzędzia IronOCR, takie jak logowanie, typowane wyjątki i punkty pewności, zapewniają wszechstronne wsparcie w identyfikacji i rozwiązywaniu problemów, tym samym ulepszając proces debugowania.

Dlaczego rejestrowanie błędów jest ważne w aplikacjach OCR?

Rejestrowanie błędów jest kluczowe, ponieważ dostarcza informacji o tym, co poszło nie tak podczas przetwarzania OCR, umożliwiając programistom szybkie diagnozowanie i naprawianie problemów w ich aplikacjach.

Jaką rolę odgrywają typowane wyjątki w debugowaniu IronOCR?

Typowane wyjątki w IronOCR dostarczają szczegółowych informacji o błędach, co ułatwia programistom zrozumienie natury problemu i zastosowanie odpowiednich rozwiązań podczas debugowania.

Jak deweloperzy mogą skorzystać z funkcji debugowania IronOCR?

Deweloperzy mogą wykorzystać funkcje debugowania IronOCR do efektywnego rozwiązywania problemów, poprawy stabilności aplikacji i poprawy ogólnej jakości wyników OCR.

A PHP Error was encountered

Severity: Warning

Message: Illegal string offset 'name'

Filename: sections/author_component.php

Line Number: 18

Backtrace:

File: /var/www/ironpdf.com/application/views/main/sections/author_component.php
Line: 18
Function: _error_handler

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 63
Function: view

File: /var/www/ironpdf.com/application/views/products/sections/three_column_docs_page_structure.php
Line: 64
Function: main_view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 88
Function: view

File: /var/www/ironpdf.com/application/views/products/how-to/index.php
Line: 2
Function: view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 88
Function: view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 552
Function: view

File: /var/www/ironpdf.com/application/controllers/Products/Howto.php
Line: 31
Function: render_products_view

File: /var/www/ironpdf.com/index.php
Line: 292
Function: require_once

k

A PHP Error was encountered

Severity: Warning

Message: Illegal string offset 'title'

Filename: sections/author_component.php

Line Number: 38

Backtrace:

File: /var/www/ironpdf.com/application/views/main/sections/author_component.php
Line: 38
Function: _error_handler

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 63
Function: view

File: /var/www/ironpdf.com/application/views/products/sections/three_column_docs_page_structure.php
Line: 64
Function: main_view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 88
Function: view

File: /var/www/ironpdf.com/application/views/products/how-to/index.php
Line: 2
Function: view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 88
Function: view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 552
Function: view

File: /var/www/ironpdf.com/application/controllers/Products/Howto.php
Line: 31
Function: render_products_view

File: /var/www/ironpdf.com/index.php
Line: 292
Function: require_once

k

A PHP Error was encountered

Severity: Warning

Message: Illegal string offset 'comment'

Filename: sections/author_component.php

Line Number: 48

Backtrace:

File: /var/www/ironpdf.com/application/views/main/sections/author_component.php
Line: 48
Function: _error_handler

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 63
Function: view

File: /var/www/ironpdf.com/application/views/products/sections/three_column_docs_page_structure.php
Line: 64
Function: main_view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 88
Function: view

File: /var/www/ironpdf.com/application/views/products/how-to/index.php
Line: 2
Function: view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 88
Function: view

File: /var/www/ironpdf.com/application/libraries/Render.php
Line: 552
Function: view

File: /var/www/ironpdf.com/application/controllers/Products/Howto.php
Line: 31
Function: render_products_view

File: /var/www/ironpdf.com/index.php
Line: 292
Function: require_once

k
Gotowy, aby rozpocząć?
Nuget Pliki do pobrania 5,896,332 | Wersja: 2026.5 just released
Still Scrolling Icon

Wciąż przewijasz?

Czy chcesz szybko dowodu? PM > Install-Package IronOcr
uruchom próbkę obserwuj, jak twój obraz staje się tekstem z możliwością wyszukiwania.