Popularity
3.6
Stable
Activity
4.5
-
75
4
8

Programming language: Go
License: BSD 2-clause "Simplified" License
Tags: Files    
Latest version: v0.7.8

opc alternatives and similar packages

Based on the "Files" category.
Alternatively, view opc alternatives based on common mentions on social networks and blogs.

Do you think we are missing an alternative of opc or a related project?

Add another 'Files' Package

README

opc

PkgGoDev Build Status Go Report Card codecov codeclimate License Mentioned in Awesome Go

Package opc implements the ISO/IEC 29500-2, also known as the Open Packaging Convention.

The Open Packaging specification describes an abstract model and physical format conventions for the use of XML, Unicode, ZIP, and other openly available technologies and specifications to organize the content and resources of a document within a package.

The OPC is the foundation technology for many new file formats: .docx, .pptx, .xlsx, .3mf, .dwfx, ...

Features

  • [x] Package reader and writer
  • [x] Package core properties and relationships
  • [x] Part relationships
  • [x] ZIP mapping
  • [x] Package, relationships and parts validation against specs
  • [ ] Part interleaved pieces
  • [ ] Digital signatures

Examples

Write

// Create a file to write our archive to.
f, _ := os.Create("example.xlsx")

// Create a new OPC archive.
w := opc.NewWriter(f)

// Create a new OPC part.
name := opc.NormalizePartName("docs\\readme.txt")
part, _ := w.Create(name, "text/plain")

// Write content to the part.
part.Write([]byte("This archive contains some text files."))

// Make sure to check the error on Close.
w.Close()

Read

r, _ := opc.OpenReader("testdata/test.xlsx")
defer r.Close()

// Iterate through the files in the archive,
// printing some of their contents.
for _, f := range r.Files {
  fmt.Printf("Contents of %s with type %s :\n", f.Name, f.ContentType)
  rc, _ := f.Open()
  io.CopyN(os.Stdout, rc, 68)
  rc.Close()
  fmt.Println()
}


*Note that all licence references and agreements mentioned in the opc README section above are relevant to that project's source code only.