ホームページ バックエンド開発 C#.Net チュートリアル C# EXCEL インポートおよびエクスポート クラス (OLEDB メソッド) サンプル コードの詳細

C# EXCEL インポートおよびエクスポート クラス (OLEDB メソッド) サンプル コードの詳細

Mar 02, 2017 am 11:43 AM

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

public static class ExcelHelper

    {

 

 

        #region 导入

 

 

        /// <summary>

        /// 导入EXCEL(默认的sheet)

        /// </summary>

        /// <param name="fileName"></param>

        /// <returns></returns>

        public static System.Data.DataTable ImpExcelDt(string fileName)

        {

            return ImpExcelDt(fileName, "Sheet1");

        }

 

 

        /// <summary>

        /// excel 导入

        /// </summary>

        /// <param name="fileName"></param>

        /// <param name="sheetName"></param>

        /// <returns></returns>

        public static System.Data.DataTable ImpExcelDt(string fileName, string sheetName)

        {

            try

            {

                if (!File.Exists(fileName))

                {

                    return null;

                }

                string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties=&#39;Excel 8.0;HDR=False;IMEX=1&#39;";

                OleDbConnection myConn = new OleDbConnection(strCon);

                string strCom = " SELECT * FROM [" + sheetName + "$] ";

                myConn.Open();

                OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, myConn);

                DataSet myDataSet = new DataSet();

                myCommand.Fill(myDataSet, "[" + sheetName + "$]");

                myConn.Close();

 

 

                System.Data.DataTable dt = myDataSet.Tables[0];

                return dt;

            }

            catch(Exception ex)

            {

                throw ex;

            }

        }

 

 

        #endregion

 

 

        #region 导出到EXCEL

 

 

        /// <summary>

        /// 将数据导出到指定的Excel文件中

        /// </summary>

        /// <param name="listView">System.Windows.Forms.ListView,指定要导出的数据源</param>

        /// <param name="destFileName">指定目标文件路径</param>

        /// <param name="tableName">要导出到的表名称</param>

        /// <param name="overWrite">指定是否覆盖已存在的表</param>

        /// <returns>导出的记录的行数</returns>

        public static int ExportToExcel(System.Data.DataTable dt, string destFileName, string tableName)

        {

            if (File.Exists(destFileName))

            {

                File.Delete(destFileName);

            }

            //得到字段名

            string szFields = "";

            string szValues = "";

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

            {

                szFields += "[" + dt.Columns[i] + "],";

            }

            szFields = szFields.TrimEnd(&#39;,&#39;);

            //定义数据连接

            OleDbConnection connection = new OleDbConnection();

            connection.ConnectionString = GetConnectionString(destFileName);

            OleDbCommand command = new OleDbCommand();

            command.Connection = connection;

            command.CommandType = CommandType.Text;

            //打开数据库连接

            try

            {

                connection.Open();

            }

            catch

            {

                throw new Exception("目标文件路径错误。");

            }

            //创建数据库表

            try

            {

                command.CommandText = GetCreateTableSql("[" + tableName + "]", szFields.Split(&#39;,&#39;));

                command.ExecuteNonQuery();

            }

            catch (Exception ex)

            {

                //如果允许覆盖则删除已有数据

                throw ex;

            }

            try

            {

                //循环处理数据------------------------------------------

                int recordCount = 0;

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

                {

                    szValues = "";

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

                    {

                            szValues += "&#39;" + dt.Rows[i][j] + "&#39;,";

                        

                    }

                    szValues = szValues.TrimEnd(&#39;,&#39;);

                    //组合成SQL语句并执行

                    string szSql = "INSERT INTO [" + tableName + "](" + szFields + ") VALUES(" + szValues + ")";

                    command.CommandText = szSql;

                    recordCount += command.ExecuteNonQuery();

                }

                connection.Close();

                return recordCount;

            }

            catch (Exception ex)

            {

                throw ex;

            }

        }

        //得到连接字符串

        private static String GetConnectionString(string fullPath)

        {

            string szConnection;

            szConnection = "Provider=Microsoft.JET.OLEDB.4.0;Extended Properties=Excel 8.0;data source=" + fullPath;

            return szConnection;

        }

 

 

        //得到创建表的SQL语句

        private static string GetCreateTableSql(string tableName, string[] fields)

        {

            string szSql = "CREATE TABLE " + tableName + "(";

            for (int i = 0; i < fields.Length; i++)

            {

                szSql += fields[i] + " VARCHAR(200),";

            }

            szSql = szSql.TrimEnd(&#39;,&#39;) + ")";

            return szSql;

        }

 

 

        #endregion

    }

ログイン後にコピー

上記は、C# EXCEL インポートおよびエクスポート クラス (OLEDB メソッド) のサンプル コードの詳細です。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) を参照してください。


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

C# を使用した Active Directory C# を使用した Active Directory Sep 03, 2024 pm 03:33 PM

C# を使用した Active Directory のガイド。ここでは、Active Directory の概要と、C# での動作方法について、構文と例とともに説明します。

C# の乱数ジェネレーター C# の乱数ジェネレーター Sep 03, 2024 pm 03:34 PM

C# の乱数ジェネレーターのガイド。ここでは、乱数ジェネレーターの仕組み、擬似乱数の概念、安全な数値について説明します。

C# シリアル化 C# シリアル化 Sep 03, 2024 pm 03:30 PM

C# シリアル化のガイド。ここでは、C# シリアル化オブジェクトの導入、手順、作業、例についてそれぞれ説明します。

C# データ グリッド ビュー C# データ グリッド ビュー Sep 03, 2024 pm 03:32 PM

C# データ グリッド ビューのガイド。ここでは、SQL データベースまたは Excel ファイルからデータ グリッド ビューをロードおよびエクスポートする方法の例について説明します。

C# のパターン C# のパターン Sep 03, 2024 pm 03:33 PM

C# のパターンのガイド。ここでは、C# のパターンの概要と上位 3 種類について、その例とコード実装とともに説明します。

C# の素数 C# の素数 Sep 03, 2024 pm 03:35 PM

C# の素数ガイド。ここでは、C# における素数の導入と例を、コードの実装とともに説明します。

C# の階乗 C# の階乗 Sep 03, 2024 pm 03:34 PM

C# の Factorial のガイド。ここでは、C# での階乗の概要について、さまざまな例とコード実装とともに説明します。

マルチスレッドと非同期C#の違い マルチスレッドと非同期C#の違い Apr 03, 2025 pm 02:57 PM

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

See all articles