Codecrete.SwissQRBill.Core 3.0.5

.NET Standard 2.0
Install-Package Codecrete.SwissQRBill.Core -Version 3.0.5
dotnet add package Codecrete.SwissQRBill.Core --version 3.0.5
<PackageReference Include="Codecrete.SwissQRBill.Core" Version="3.0.5" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Codecrete.SwissQRBill.Core --version 3.0.5
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Codecrete.SwissQRBill.Core, 3.0.5"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install Codecrete.SwissQRBill.Core as a Cake Addin
#addin nuget:?package=Codecrete.SwissQRBill.Core&version=3.0.5

// Install Codecrete.SwissQRBill.Core as a Cake Tool
#tool nuget:?package=Codecrete.SwissQRBill.Core&version=3.0.5
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

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.

QR Bill

More examples can be found in the Wiki

Features

The Swiss QR bill library:

  • generates QR bills as PDF and SVG files (see home page for PNG and EMF)
  • 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)
  • is built for .NET Standard 2.0, i.e. it runs with .NET Core 2.0 or higher, .NET Framework 4.6.1 or higher, Mono 5.4 or higher, Universal Windows Platform 10.0.16299 or higher, Xamarin etc.
  • this core library is light-weight and has a single dependency: Net.Codecrete.QrCodeGenerator
  • see home page for more examples and other library versions including PNG and EMF generation

Getting started

  1. Create a new Visual Studio project for .NET Core 3.x (File > New > Project... / Visual C# > .NET Core > Console App (.NET Core))

  2. 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.Core -Version 3.0.5
  1. 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) }");
        }
    }
}
  1. 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
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on Codecrete.SwissQRBill.Core:

Package Downloads
Codecrete.SwissQRBill.Generator

Generates the new QR bills for invoicing in Switzerland. The Swiss QR bill library: - is a platform-independent library supporting PDF, SVG and PNG (based on SkiaSharp), - parses the invoice data embedded in the QR code, - generates payment slips (105mm by 210mm), A4 sheets or QR codes, - is multilingual: German, French, Italian, English, Romansh, - validates the invoice data and provides detailed validation information, - adds and retrieves structured bill information (according to Swico S1), - is easy to use and comes with many examples, - is small and fast, - is free – even for commecial use (MIT License), - is built for .NET Standard 2.0 and runs on all modern .NET platforms, - uses SkiaSharp for multi-platform support (use Codecrete.SwissQRBill.Core for minimal dependencies). See home page https://github.com/manuelbl/SwissQRBill.NET for examples and other library versions.

Codecrete.SwissQRBill.Windows

Generates the new QR bills for invoicing in Switzerland. The Swiss QR bill library: - is a Windows-specific library supporting PDF, SVG, PNG and EMF, - parses the invoice data embedded in the QR code, - generates payment slips (105mm by 210mm), A4 sheets or QR codes, - is multilingual: German, French, Italian, English, Romansh, - validates the invoice data and provides detailed validation information, - adds and retrieves structured bill information (according to Swico S1), - is easy to use and comes with many examples, - is small and fast, - is free – even for commecial use (MIT License), - is built for .NET Standard 2.0 and runs on all Windows variants of .NET. See home page https://github.com/manuelbl/SwissQRBill.NET for examples and platform-independent library versions.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.5 12,879 7/5/2022
3.0.4 9,069 6/11/2022
3.0.3 15,333 3/12/2022
3.0.2 448 2/25/2022
3.0.1 28,959 12/30/2021
3.0.0 527 12/28/2021

New light-weight version without any dependency on a raster graphics library
New in version 3.0.5:
- Support QR bill data using CR (in addition to NL and CR/NL)