国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
悔しい経験
ビジネスツール
オンラインサービス
オープンソース ライブラリ
ヘッドレス モードの LibreOffice
私のソリューションの仕組み
主な機(jī)能
一時(shí)ディレクトリ方式
実裝の詳細(xì)
ワークフロー
スタートガイド
GitHub リポジトリ
Docker イメージ
Docker コンテナを?qū)g行します
他の言語(yǔ)との統(tǒng)合の例
C#
Node.js
Python
行きます
課題とトレードオフ
畫像サイズ
価値がある理由
結(jié)論
ホームページ バックエンド開発 Golang 無料の Excel から PDF へのコンバーターを見つけるのに苦労: 私の旅と解決策

無料の Excel から PDF へのコンバーターを見つけるのに苦労: 私の旅と解決策

Jan 12, 2025 pm 04:05 PM

The Struggle of Finding a Free Excel to PDF Converter: My Journey and Solution

多くのプロジェクトでは、レポートの生成、データの共有、ドキュメントの作成など、Excel ファイルを PDF 形式に変換する必要があります。多くの開発者と同様、私も當(dāng)初、これは簡(jiǎn)単に自動(dòng)化できるタスクだと考えていました。ただし、無料で信頼性の高いソリューションを見つける旅には、制限、互換性の問題、高価な商用ツールなどの課題が伴います。

最終的に、私はこれらの困難を克服し、獨(dú)自の Excel to PDF コンバータ を構(gòu)築し、同じジレンマに直面する可能性のある他の開発者がオープンソース ツールとして利用できるようにしました。


悔しい経験

ビジネスツール

最初の検索結(jié)果は、Aspose.Cells、Syncfusion などの有料ソリューションを示していました。これらは強(qiáng)力ですが、ライセンス料が高いため、小規(guī)模または個(gè)人のプロジェクトには法外な費(fèi)用がかかります。

オンラインサービス

無料のオンラインコンバーターは良い選択のように思えますが、自動(dòng)化には適していません。これらのツールには、プライバシーの問題 (ファイルがサードパーティのサーバーにアップロードされるため)、ファイル サイズの制限があり、プログラミング API が提供されていないことがよくあります。

オープンソース ライブラリ

オープンソース ライブラリも調(diào)査しましたが、ほとんどのライブラリには Excel ファイルを PDF に変換する機(jī)能がありませんでした。この機(jī)能を備えたライブラリであっても、多くの場(chǎng)合、信頼性が低いか、最新の Microsoft Office 形式をサポートしていません。


ヘッドレス モードの LibreOffice

數(shù)週間検索した結(jié)果、ヘッドレス モードで LibreOffice を使用する方法を見つけました。 LibreOffice は、Excel などの複數(shù)のファイル形式を PDF に変換できる、無料のオープンソース オフィス スイートです。ヘッドレス モードで実行する場(chǎng)合はコマンド ライン経由で動(dòng)作するため、自動(dòng)化に最適です。


私のソリューションの仕組み

開発者が使いやすくするために、REST API として機(jī)能する軽量の Go ベースの HTTP サーバー を構(gòu)築しました。このサーバーは LibreOffice の機(jī)能をカプセル化し、あらゆるプログラミング言語(yǔ)が HTTP リクエスト経由で LibreOffice と対話できるようにします。

主な機(jī)能

  1. 複數(shù)のファイル形式をサポート: .xlsx、.xls、.csv、.docx、.pptx およびその他の形式をサポートします。
  2. 自動(dòng)クリーンアップ: ディスク領(lǐng)域を節(jié)約するために、一時(shí)ファイルは 1 時(shí)間後に自動(dòng)的に削除されます。
  3. カスタム フォント: カスタム フォントは、GitHub リポジトリのクローンを作成するか、Docker ボリュームを使用してインストールできます。
  4. 言語(yǔ)間の統(tǒng)合: HTTP をサポートする任意のプログラミング言語(yǔ)で動(dòng)作します。

一時(shí)ディレクトリ方式

システムの一時(shí)ディレクトリに依存する代わりに、カスタム ./tmp ディレクトリを使用することにしました。システムの一時(shí)ディレクトリには予期しないアクセス許可が設(shè)定されている場(chǎng)合があるため、これにより一貫した動(dòng)作が保証されます。


実裝の詳細(xì)

ワークフロー

  1. ファイル アップロード: クライアントは /convert エンドポイントを使用して、POST リクエストを通じて Excel ファイルをアップロードします。
  2. 一時(shí)ストレージ: サーバーは、タイムスタンプに基づいたファイル名でファイルを ./tmp ディレクトリに保存します。
  3. Convert: ヘッドレス モードで LibreOffice を呼び出してファイルを PDF に変換し、結(jié)果を同じディレクトリに保存します。
  4. ファイルのクリーニング: バックグラウンドのゴルーチンは、1 時(shí)間より古いファイルを削除します。
  5. Response: 変換された PDF を HTTP レスポンスとして返します。

スタートガイド

GitHub リポジトリ

ソース コードは http://miracleart.cn/link/5b1add8961a1cfa07e60838ffd0f83e7 で見つけることができます。

Docker イメージ

このプロジェクトは、Docker イメージ: wteja/pdf-converter も提供します。

Docker コンテナを?qū)g行します

<code>docker pull wteja/pdf-converter
docker run -p 5000:5000 wteja/pdf-converter</code>

他の言語(yǔ)との統(tǒng)合の例

サービスは HTTP 経由で公開されるため、任意のプログラミング言語(yǔ)を使用してサービスを操作できます。

C#

var client = new HttpClient();
var fileContent = new ByteArrayContent(File.ReadAllBytes("example.xlsx"));
var formData = new MultipartFormDataContent { { fileContent, "file", "example.xlsx" } };

var response = await client.PostAsync("http://localhost:5000/convert", formData);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
File.WriteAllBytes("output.pdf", pdfBytes);

Node.js

const axios = require("axios");
const FormData = require("form-data");
const fs = require("fs");

const form = new FormData();
form.append("file", fs.createReadStream("example.xlsx"));

axios.post("http://localhost:5000/convert", form, { headers: form.getHeaders() })
  .then(response => fs.writeFileSync("output.pdf", response.data))
  .catch(console.error);

Python

import requests

with open("example.xlsx", "rb") as f:
    response = requests.post("http://localhost:5000/convert", files={"file": f})

with open("output.pdf", "wb") as f:
    f.write(response.content)

行きます

package main

import (
    "bytes"
    "io"
    "mime/multipart"
    "net/http"
    "os"
)

func main() {
    file, _ := os.Open("example.xlsx")
    defer file.Close()

    body := &bytes.Buffer{}
    writer := multipart.NewWriter(body)
    part, _ := writer.CreateFormFile("file", "example.xlsx")
    io.Copy(part, file)
    writer.Close()

    req, _ := http.NewRequest("POST", "http://localhost:5000/convert", body)
    req.Header.Set("Content-Type", writer.FormDataContentType())

    resp, _ := http.DefaultClient.Do(req)
    defer resp.Body.Close()

    out, _ := os.Create("output.pdf")
    defer out.Close()
    io.Copy(out, resp.Body)
}

課題とトレードオフ

畫像サイズ

LibreOffice の依存関係により、Docker イメージのサイズは 2.67 GB です。 Alpine などの小さなイメージをテストしましたが、それらには最新の Microsoft Office 形式と互換性のない古いバージョンの LibreOffice が含まれていました。 Debian は最新の LibreOffice を提供しますが、生成されるイメージは大きくなります (約 3 GB)。

価値がある理由

畫像サイズが大きいことは、商用ソリューションのコストと比較して許容できるトレードオフです。セットアップが完了すると、追加のライセンス料金を支払うことなく、イメージを複數(shù)のプロジェクトで再利用できます。


結(jié)論

無料の Excel から PDF へのコンバーターを見つけるのに苦労した私は、ヘッドレス モードで LibreOffice を使用して獨(dú)自のソリューションを構(gòu)築することにしました。完璧ではありませんが、無料で信頼性が高く、柔軟性があります。もしあなたが同じ課題に直面しているなら、このプロジェクトがあなたの時(shí)間と労力を節(jié)約することを願(yuàn)っています。

GitHub でプロジェクトをチェックアウトするか、Docker Hub から Docker イメージをプルしてください。それがどのように機(jī)能するか、または改善のための提案がある場(chǎng)合はお知らせください。

以上が無料の Excel から PDF へのコンバーターを見つけるのに苦労: 私の旅と解決策の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

デフォルトでGoの靜的リンクの意味は何ですか? デフォルトでGoの靜的リンクの意味は何ですか? Jun 19, 2025 am 01:08 AM

プログラムをデフォルトでスタンドアロンのバイナリにコンパイルします。主な理由は靜的リンクです。 1.よりシンプルな展開:依存関係ライブラリの追加インストールは、Linux分布全體で直接実行できます。 2。バイナリサイズの大きい:すべての依存関係を含むと、ファイルサイズが増加しますが、構(gòu)築フラグまたは圧縮ツールを通じて最適化できます。 3.予測(cè)可能性とセキュリティの高まり:外部ライブラリバージョンの変更によってもたらされたリスクを避け、安定性を高めます。 4.制限された操作の柔軟性:共有ライブラリのホットアップデートはできません。依存関係の脆弱性を修正するには、再コンパイルと展開が必要です。これらの機(jī)能により、CLIツール、マイクロサービス、その他のシナリオに適していますが、ストレージが制限されているか、集中管理に依存している環(huán)境でトレードオフが必要です。

Cのような手動(dòng)メモリ管理なしでメモリの安全性をどのように保証しますか? Cのような手動(dòng)メモリ管理なしでメモリの安全性をどのように保証しますか? Jun 19, 2025 am 01:11 AM

guensuresmemorysafetywithoutwithoutmanagemationgarbagecolectrection、nopointerariThmetic、safeconcurrency、andruntimechecks.first、go’sgarbagecollectorectivative -sunusedmemory、rieksanddanglingpointers.second、itdidilowsepointe

GOでバッファーチャネルを作成するにはどうすればよいですか? (例えば、make(chan int、10)) GOでバッファーチャネルを作成するにはどうすればよいですか? (例えば、make(chan int、10)) Jun 20, 2025 am 01:07 AM

GOでバッファチャネルを作成するには、Make関數(shù)の容量パラメーターを指定するだけです。バッファチャネルは、指定された容量を超えない限り、受信機(jī)がない場(chǎng)合に送信操作が一時(shí)的にデータを保存できるようにします。たとえば、ch:= make(chanint、10)は、最大10個(gè)の整數(shù)値を保存できるバッファチャネルを作成します。バッファーされていないチャネルとは異なり、データは送信時(shí)にすぐにブロックされませんが、データはレシーバーによって奪われるまで一時(shí)的にバッファーに保存されます。それを使用する場(chǎng)合、注意してください。1。メモリの無駄や頻繁なブロックを避けるために、容量設(shè)定は妥當(dāng)でなければなりません。 2。バッファは、バッファーにメモリの問題が無期限に蓄積されないようにする必要があります。 3.信號(hào)は、リソースを保存するために、chantruct {}タイプを渡すことができます。一般的なシナリオには、並行性の數(shù)、生産者消費(fèi)者モデル、および差別化の制御が含まれます

システムプログラミングタスクにGOにどのように使用できますか? システムプログラミングタスクにGOにどのように使用できますか? Jun 19, 2025 am 01:10 AM

GOは、Cなどのコンパイルされた言語(yǔ)のパフォーマンスと、最新言語(yǔ)の使いやすさとセキュリティを組み合わせているため、システムプログラミングに最適です。 1.ファイルとディレクトリの操作に関して、GOのOSパッケージは、ファイルとディレクトリが存在するかどうかの作成、削除、名前変更、チェックをサポートします。 OS.ReadFileを使用して、バックアップスクリプトまたはログ処理ツールの書き込みに適した1行のコードでファイル全體を読み取ります。 2。プロセス管理の観點(diǎn)から、OS/EXECパッケージのexec.command関數(shù)は、外部コマンドを?qū)g行し、出力をキャプチャし、環(huán)境変數(shù)を設(shè)定し、入力と出力フローをリダイレクトし、自動(dòng)化ツールと展開スクリプトに適したプロセスライフサイクルを制御できます。 3。ネットワークと並行性の観點(diǎn)から、ネットパッケージはTCP/UDPプログラミング、DNSクエリ、オリジナルセットをサポートします。

GOの機(jī)能的オプションパターンは何ですか、そしてそれらはいつコンストラクターの設(shè)計(jì)に役立ちますか? GOの機(jī)能的オプションパターンは何ですか、そしてそれらはいつコンストラクターの設(shè)計(jì)に役立ちますか? Jun 14, 2025 am 12:21 AM

functionaloptionsingoareadesignsigntocreateflexibleandmaintainableconstructorswithmanyoptionalparameters.insteadofusinglongparameterlistsorconctructorovers、thispatternpassessessunctions.thatmodififythisthififysconfiguration.thiscuration.

GOの構(gòu)造インスタンスでメソッドを呼び出すにはどうすればよいですか? GOの構(gòu)造インスタンスでメソッドを呼び出すにはどうすればよいですか? Jun 24, 2025 pm 03:17 PM

GO言語(yǔ)では、構(gòu)造メソッドを呼び出すには、最初に構(gòu)造と受信機(jī)を結(jié)合する方法を定義し、ポイント番號(hào)を使用してアクセスする必要があります。構(gòu)造の長(zhǎng)方形を定義した後、メソッドは値受信機(jī)またはポインターレシーバーを介して宣言できます。 1。func(rrectangle)領(lǐng)域()intなどの値受信機(jī)を使用し、rect.area()を介して直接呼び出します。 2.構(gòu)造を変更する必要がある場(chǎng)合は、FUNC(r*長(zhǎng)方形)setWidth(...)などのポインターレシーバーを使用し、GOはポインターと値の変換を自動(dòng)的に処理します。 3.構(gòu)造を埋め込むと、埋め込まれた構(gòu)造の方法が改善され、外側(cè)の構(gòu)造を介して直接呼び出すことができます。 4。GOは、Getter/Setterを使用する必要はありません。

GOのインターフェイスとは何ですか?また、それらを定義するにはどうすればよいですか? GOのインターフェイスとは何ですか?また、それらを定義するにはどうすればよいですか? Jun 22, 2025 pm 03:41 PM

Goでは、インターフェイスは、実裝を指定せずに動(dòng)作を定義するタイプです。インターフェイスはメソッドシグネチャで構(gòu)成され、これらのメソッドを?qū)g裝する任意のタイプは、インターフェイスを自動(dòng)的に満たします。たとえば、speak()メソッドを含むスピーカーインターフェイスを定義する場(chǎng)合、メソッドを?qū)g裝するすべてのタイプをスピーカーと見なすことができます。インターフェイスは、一般的な関數(shù)、抽象的な実裝の詳細(xì)、およびテストで模擬オブジェクトの使用に適しています。インターフェイスの定義は、インターフェイスキーワードを使用し、メソッドシグネチャをリストし、インターフェイスを?qū)g裝するためにタイプを明示的に宣言することはありません。一般的なユースケースには、ログ、フォーマット、さまざまなデータベースまたはサービスの抽象化、および通知システムが含まれます。たとえば、犬とロボットの両方のタイプは、話す方法を?qū)g裝し、それらを同じannoに渡すことができます

IOパッケージを使用して、GOの入力ストリームと出力ストリームを使用するにはどうすればよいですか? IOパッケージを使用して、GOの入力ストリームと出力ストリームを使用するにはどうすればよいですか? Jun 20, 2025 am 11:25 AM

thegoiopackageProvidesInterfacesLikerEaderAnderandRitoHandlei/ooperationsUniformlyAcrossources.1.io.Reader'SreadMethodenablessablesSreadingSuourCessuchasfilesorhtttttttttts

See all articles