Codecrete.SwissQRBill.Windows
3.0.4
Install-Package Codecrete.SwissQRBill.Windows -Version 3.0.4
dotnet add package Codecrete.SwissQRBill.Windows --version 3.0.4
<PackageReference Include="Codecrete.SwissQRBill.Windows" Version="3.0.4" />
paket add Codecrete.SwissQRBill.Windows --version 3.0.4
#r "nuget: Codecrete.SwissQRBill.Windows, 3.0.4"
// Install Codecrete.SwissQRBill.Windows as a Cake Addin
#addin nuget:?package=Codecrete.SwissQRBill.Windows&version=3.0.4
// Install Codecrete.SwissQRBill.Windows as a Cake Tool
#tool nuget:?package=Codecrete.SwissQRBill.Windows&version=3.0.4
Swiss QR Bill for .NET
Open-source .NET library to generate Swiss QR bills. Try it yourself and create a QR bill.
Introduction
The Swiss QR bill is the new QR code based payment format that started on 30 June, 2020. The old payment slip will no longer be accepted after 30 September 2022.
The new payment slip will be sent electronically in most cases. But it can still be printed at the bottom of an invoice or added to the invoice on a separate sheet. The payer scans the QR code with his/her mobile banking app to initiate the payment. The payment just needs to be confirmed.
If the invoicing party adds structured bill information (VAT rates, payment conditions etc.) to the QR bill, posting in accounts payable can be automated. The invoicing party can also automate the accounts receivable processing as the payment includes all relevant data including a reference number. The Swiss QR bill is convenient for the payer and payee.
More examples can be found in the Wiki
Features
The Swiss QR bill library:
- generates QR bills as PDF, SVG, PNG and EMF files
- generates payment slips (105mm by 210mm), A4 sheets or QR codes
- multilingual: German, French, Italian, English, Romansh
- validates the invoice data and provides detailed validation information
- adds or retrieves structured bill information (according to Swico S1)
- parses the invoice data embedded in the QR code
- is easy to use (see example below)
- is small and fast
- is free – even for commercial use (MIT License)
- runs on all Windows version of .NET: .NET Core 2.0 or higher, .NET Framework 4.6.1 or higher, Universal Windows Platform 10.0.16299
- see home page for more examples and other library versions (e.g. platform-independent ones)
Getting started
Create a new Visual Studio project for .NET Core 3.x (File > New > Project... / Visual C# > .NET Core > Console App (.NET Core))
Add the library via NuGet:
Either via Project > Manage NuGet Packages... / Browse / search for qrbill / Install
Or by running a command in the Package Manager Console
Install-Package Codecrete.SwissQRBill.Windows -Version 3.0.4
- Add the code:
using Codecrete.SwissQRBill.Generator;
using System;
using System.IO;
namespace Codecrete.SwissQRBill.Examples.Basic
{
class Program
{
static void Main(string[] args)
{
// Setup bill data
Bill bill = new Bill
{
// creditor data
Account = "CH4431999123000889012",
Creditor = new Address
{
Name = "Robert Schneider AG",
AddressLine1 = "Rue du Lac 1268/2/22",
AddressLine2 = "2501 Biel",
CountryCode = "CH"
},
// payment data
Amount = 199.95m,
Currency = "CHF",
// debtor data
Debtor = new Address
{
Name = "Pia-Maria Rutschmann-Schnyder",
AddressLine1 = "Grosse Marktgasse 28",
AddressLine2 = "9400 Rorschach",
CountryCode = "CH"
},
// more payment data
Reference = "210000000003139471430009017",
UnstructuredMessage = "Abonnement für 2020",
// output format
Format = new BillFormat
{
Language = Language.DE,
GraphicsFormat = GraphicsFormat.SVG,
OutputSize = OutputSize.QrBillOnly
}
};
// Generate QR bill
byte[] svg = QRBill.Generate(bill);
// Save generated SVG file
const string path = "qrbill.svg";
File.WriteAllBytes(path, svg);
Console.WriteLine($"QR bill saved at { Path.GetFullPath(path) }");
}
}
}
- Run it
API documention
See DocFX API Documentation
Further topics
Product | Versions |
---|---|
.NET | net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows |
.NET Core | netcoreapp2.0 netcoreapp2.1 netcoreapp2.2 netcoreapp3.0 netcoreapp3.1 |
.NET Standard | netstandard2.0 netstandard2.1 |
.NET Framework | net461 net462 net463 net47 net471 net472 net48 |
MonoAndroid | monoandroid |
MonoMac | monomac |
MonoTouch | monotouch |
Tizen | tizen40 tizen60 |
Xamarin.iOS | xamarinios |
Xamarin.Mac | xamarinmac |
Xamarin.TVOS | xamarintvos |
Xamarin.WatchOS | xamarinwatchos |
-
.NETStandard 2.0
- Codecrete.SwissQRBill.Core (>= 3.0.4)
- System.Drawing.Common (>= 4.5.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
New in releases 3.0.4:
- Show country code for LI and if payer is in foreign country