• Anasayfa
  • Hakkımızda
  • Etkinlikler
  • Destek Verin
  • Site Haritası
  • Giriş Yap
  • Üye Ol
  • Facebook
  • Twitter
  • RSS
Yazılım Dilleri
  • Soru - Cevap
  • EĞİTİM SETİ
  • KATEGORİ
  • DUYURU
  • TEKNOLOJİ HABERLERİ

Son Sorular

  • 23.04.2016 00:55:33C programlama 2 oyun
  • 20.04.2016 16:34:41Local Database
  • 15.04.2016 14:26:15Fatura kayıt işlemi
  • 21.03.2016 01:55:30C# problem

Popüler Sorular

  • 27.05.2012 05:49:50Asp.Net ile Date time alana veri ekleyemiiyorum ?
  • 2.04.2012 00:45:18.exe uzantılı dosya için dijital imza nerde nasıl alınır.
  • 12.05.2012 08:44:49Acil Yardım
  • 27.05.2012 13:46:51veri tabanı bağlantısı
  • .Net Framework
  • 8085 Assembly
  • Active Directory
  • ADO.NET
  • Android
  • Apple IOS
  • Arduino
  • ASP.NET
  • ASP.NET MVC
  • Blackberry
  • C#.Net
  • C++
  • CCG Framework
  • CISCO
  • CSS
  • Diğer
  • Dreamweaver
  • Entity Framework
  • Exchange Server
  • Gömülü Sistemler
  • GSM Programlama
  • Güncel
  • Güvenlik
  • HTML5
  • Java
  • Javascript / JQuery
  • Jira
  • Kariyer ve İş Yaşamı
  • LINQ
  • LibreOffice
  • Linux
  • Matlab
  • Microsoft Dynamics CRM
  • Mobil Uygulama Geliştirme
  • MySQL
  • NoSQL
  • Oracle
  • OWIN
  • PFSense
  • PHP
  • Powershell
  • Python
  • Sanallastirma
  • SAP-ABAP
  • SCOM 2012
  • SEO
  • Sharepoint 2010
  • Sharepoint 2013
  • Silverlight
  • Sistem Analiz ve Tasarımı
  • SQL Server
  • Symantec
  • TFS
  • T-SQL
  • Ubuntu
  • VB.NET
  • Veritabanı Yönetim Sistemleri
  • Visual Studio
  • VMware
  • WCF
  • Web Hosting
  • Windows 8
  • Windows Azure
  • Windows Phone 7.1
  • Windows Phone 8
  • Windows Server
  • Wordpress
  • WPF
  • Xamarin
  • XNA
  • Yazılım Mühendisliği
  • Yöneylem Araştırması
  • ASP.NET MVC
  • Entity Framework
  • Javascript / JQuery
  • LINQ
  • PHP

Son Duyurular

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

DataGridView İçindeki Verileri Excel ve PDF’e Aktarmak

Uygulamanız içinde kullandığınız DataGridView içindeki verileri kolaylıkla Excel ve PDF'e yazdırabilirsiniz.

17.11.2012

Yazar: Serap Şen (Google+)

Kategori: C#.Net

12159

Merhaba Arkadaşlar,

Bu yazımda C# uygulamanız üzerinde DataGridView’den verilerinizi Excel ve PDF’e nasıl aktarabileceğinizi anlatacağım. Excel örneği üzerinden Word’e aktarmayı da yapabilirsiniz. Örnek kod üzerinden takip edebilirsiniz. Bu şekilde DataGridView içindeki verilerinizi kolaylıkla elde edebilirsiniz.

Excel’e aktarmak için Microsoft.Office.Interop.Excel, Word için Microsoft.Office.Interop.Word referanslarınızı eklemelisiniz.

 

PDF’e aktarabilmek için;
using iTextSharp.text;
using iTextSharp.text.pdf;

namespaceleri tanımlamanız gerekmektedir.

Uygulamamız için ortak bir class oluşturmak daha mantıklı olacaktır. Yorum satırlarıyla beraber kod örneğimi inceleyebilirsiniz.

PDF’e aktarabilmek için

using iTextSharp.text;

using iTextSharp.text.pdf;

namespaceleri tanımlamanız gerekmektedir.

 Uygulamamız için ortak bir class oluşturmak daha mantıklı olacaktır. Yorum satırlarıyla beraber kod örneğimi inceleyebilirsiniz.

 

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data;

using iTextSharp.text;

using iTextSharp.text.pdf;

using System.IO;

using System.Windows.Forms;

namespace ExcelPDFExporter.GlobalClass

{

    public class EXCELPDFExporter : DataTable

    {

        public string FileName { get; set; } //pdf oluşturacağımız dosya adı

        public string Text { get; set; } //dosyanın içinde oluşturacağımız pdf adı

        public int PdfRowIndex { get; set; } //pdfrowindex

        public string Path { get; set; } //settings içinden global olarak tanımlanan pathi almak için(dosya yolu global olarak projede settings içinde tutuluyor.Bu şekilde yolu değiştirmek isterseniz tüm projede kolaylıkla değiştirmiş olacaksınız.)

 

        /// <summary>

        /// Data table oluşturarak kolonların adlarını ekler,sonra kolonlara ait satırları doldurur

        /// </summary>

        public DataTable CreateTable(DataGridView dataGridview)

        {

            DataTable tbl = new DataTable();

            DataRow row;

            for (int i = 0; i < dataGridView.Columns.Count; i++)

            {

               tbl.Columns.Add(dataGridView.Columns[i].HeaderText, typeof(string));

            }

 

            for (int i = 0; i < dataGridView.Rows.Count; i++)

            {

                row = tbl.NewRow();

                for (int j = 0; j < dataGridView.Columns.Count; j++)

                {

                    row[dataGridView.Columns[j].HeaderText] = dataGridView.Rows[i].Cells[j].Value;

                }

                tbl.Rows.Add(row);

            }

 

            return tbl;

 

        }

 

        /// <summary>

        /// verileri PDFe aktarabilmek için itextsharp kütüphanesi tanımlandı

        /// Metot yardımı ile (create table) bağlanarak data table oluşturur,data table'ı oluşturulan pdftable'a atanır.Belge oluşturulur.

        /// Oluşan pdf belgesinin dosya adı ve belge adı eklenir.Belge açılır.itextsharp kütüphanesi kullanılarak font ayarlaması yapılır.

        /// </summary>

 

        public void ToPdf(DataGridView dataGridView1)

        {

            DataTable dtPDF = CreateTable(dataGridView1);

            Document document = new Document();

            Properties.Settings set = Properties.Settings.Default; //Settings içinde dosya yolu verildi

            string Path = set.PdfExporterPath; //dosya yolu alındı

            PdfWriter writer = PdfWriter.GetInstance(document, new FileStream(Path+Text, FileMode.Create));

            document.Open();

            iTextSharp.text.Font font5 = iTextSharp.text.FontFactory.GetFont(FontFactory.HELVETICA, 5);

            PdfPTable table = null;

            table = new PdfPTable(dataGridView1.Columns.Count);

            table.WidthPercentage = 100;

            string str = string.Empty;

            for (int i = 0; i < dataGridView1.Columns.Count; i++)

            {

                str += dataGridView1.Columns[i].HeaderText;

                if (dataGridView1.Columns.Count > i)

                    str += "+";

            }

 

            string str2 = str.TrimEnd('+').ToString();

 

            ///<summary>

            /// DataGridView kolonlarının sayısı kadar belgenin başlıkları doldurulur.

            /// Pdf hücreleri oluşturulur.Dökumandaki başlık kısmı için ilk satır oluşturulur ve colspan yapılır.

            ///</summary>

 

            PdfPCell cell = new PdfPCell(new Phrase(FileName));

            cell.Colspan = dataGridView1.Columns.Count;

            cell.HorizontalAlignment = 1; //0=Left, 1=Centre, 2=Right

            table.AddCell(cell);

 

            ///<summary>

            ///pdf tablosu hücreleri doldurulur

            ///</summary>

 

            for (int i = 0; i < dataGridView1.Columns.Count; i++)

            {

                table.AddCell(new Phrase(dataGridView1.Columns[i].HeaderText, font5));

            }

 

 

            for (int i = 0; i < dtPDF.Rows.Count; i++)

            {

                for (int j = 0; j < dtPDF.Columns.Count; j++)

                {

                    table.AddCell(new Phrase(dtPDF.Rows[i][j].ToString(), font5));

 

                    PdfRowIndex++;

                }

            }

            document.Add(table);

 

            MessageBox.Show("Kaydınız Başarıyla Tamamlanmıştır!" + "\n" + "Kayıt Yeri" + " " + Path + Text, "Aktarım Sonucu", MessageBoxButtons.OKCancel, MessageBoxIcon.Information);

            document.Close();

        }

 

        /// <summary>

        /// Gridview_Right içindeki veriler excele kaydedilir,Microsoft.Office.Interop.Excel dll referans olarak eklendi.

        /// Excel hücreleri dolduruldu

        /// </summary>

       

        public void ToExcel(string FileName, DataGridView dataGridView )

        {

            Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();

            excel.Visible = false;

            Properties.Settings set = Properties.Settings.Default; //settings içinde tanımlanan path alındı

            string Path = set.ExcelExporterPath;

            Microsoft.Office.Interop.Excel.Workbook workbook = excel.Workbooks.Add(System.Reflection.Missing.Value);

            Microsoft.Office.Interop.Excel.Worksheet sheet1 = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Sheets[1];

            Microsoft.Office.Interop.Excel.Range myRange;

            int StartCol = 1;

            int StartRow = 1;

 

            for (int i = 0; i < dataGridView.Columns.Count; i++)

            {

                myRange = (Microsoft.Office.Interop.Excel.Range)sheet1.Cells[StartRow, i + StartCol];

 

                myRange.Value2 = dataGridView.Columns[i].HeaderText;

            }

 

            StartRow++;

            for (int i = 0; i < dataGridView.Rows.Count; i++)

            {

                for (int j = 0; j < dataGridView.Columns.Count; j++)

                {

                    myRange = (Microsoft.Office.Interop.Excel.Range)sheet1.Cells[StartRow + i, StartCol + j];

                    myRange.Value2 = dataGridView.Rows[i].Cells[j].Value == null ? "" : dataGridView.Rows[i].Cells[j].Value;

                }

 

            }

            sheet1.Columns.AutoFit();

           

            workbook.SaveAs(Path + FileName, Microsoft.Office.Interop.Excel.XlFileFormat.xlWorkbookNormal,null, null,false, null, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,null, null, null, null, null);

            MessageBox.Show("Kaydınız Başarıyla Tamamlanmıştır!" + "\n" + "Kayıt Yeri" + " " + Path + FileName, "Aktarım Sonucu",MessageBoxButtons.OKCancel,MessageBoxIcon.Information);

            excel.Quit();

           

        }

    }

}

 

Class’ı kullanmak istediğiniz Windows Form üzerinde Butonların Click Event’ine;

private void ButtonExcelExport_Click(object sender, EventArgs e)

        {

                EXCELPDFExporter ExcelExport = new EXCELPDFExporter();

                ExcelExport.ToExcel(this.Name, GridView_Left); //aktarmak istediğiniz DataGridView ismini yazın

        }

 

        private void ButtonPDFExport_Click(object sender, EventArgs e)

        {

                EXCELPDFExporter PdfExport = new EXCELPDFExporter();

                PdfExport.FileName = this.Name;

                PdfExport.Text = PdfExport.FileName + ".pdf";

                PdfExport.PdfRowIndex = 1;

                PdfExport.ToPdf(GridView_Left);

        }

 

 yazmanız yeterlidir.

 

 

 

 

 

 

Yazar Hakkında

Serap Şen

Serap Şen

serapsen.net

Eskişehir Osmangazi Üniversitesi Bilgisayar Mühendisliği Bölümü Mezunu

Sosyal Medya

ORANLAR

  • 12159izleme

Arkadaşlarınla Paylaş

  • Tweet

0 Yorum

Yorum Yaz / Soru Sor

Lütfen yorum yazmak veya soru sormak için üye girişi yapınız.

Son Yorumlar

  • Hocam Link başka sayfaya yönlendiriyor.
  • merhaba benim merak ettiğim bir konu var y...
  • Merhaba download linki çalışmıyor. Rica et...
  • Nevzat Bey selamlar, Açıkçası bizler a...
  • Parametreleri Cache İşleminden Yalıtma kon...

En Güncel Sorular

  • Bilgilendirme maili (C#.Net)
  • Power Pivot (Sharepoint 2010)
  • BigInteger, BigDecimal (Asp.Net ve Asp.Net MVC)
  • visual C# ile asp nette veritabanı islemleri (Asp.Net ve Asp.Net MVC)
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ? (Sharepoint 2010)

En Son Cevap Verilen Sorular

  • Bilgilendirme maili
  • BigInteger, BigDecimal
  • visual C# ile asp nette veritabanı islemleri
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ?
  • txt dosyasına veri yazma

Twitter

Takip et: @yazilim_dilleri

En Çok Okunanlar

Elif BAYRAKDAR

C# ile SQL Server Bağlantısı, Insert, Update ve Delete Sorguları

23.05.2013

  • 120154
  • 0
Hakan Keskin

C# ile Windows Service Projesi Oluşturma, Debug Etme ve Setup Hazırlama

17.12.2013

  • 65271
  • 0
batuhan avlayan

Php - Mail Gönderme (İletişim Formu)

02.09.2013

  • 48392
  • 0

Sponsorlar

KODLAB
Pluralsight
Exchange server is
Office 365
YAZILIM DİLLERİ
Yukarı Çık
  • Hakkımızda
  • Facebook
  • Twitter
  • RSS

© Yazılım Dillerinin Buluşma Noktası | Kaynak belirtildiği sürece makaleler kopyalanabilir.
YazilimDilleri.Net sitesinde yer alan kullanıcıların oluşturduğu tüm içeriklerin yayınlanması ile ilgili yasal yükümlülükler içeriği oluşturan kullanıcıya aittir, YazilimDilleri.Net hiçbir şekilde sorumlu değildir.

Kapat

Giriş Yap

Kullanıcı Adı

Şifre

Şifremi Unuttum

KULLANICI GİRİŞİ