zoukankan      html  css  js  c++  java
  • 文件夹文件遍历并插入数据库的操作,IO Directory File的递归操作

    在我们管理内容管理系统时,数据量大时,对机器的依赖性就比较强了,比如,我要将一个文件夹中的很多图片上传到网站,一个个上传会很花时间,就想到了通过遍历文件夹得到文件名,并将路径与文件保存到数据库中对应的字段。

    下面写两个实例,

    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.SqlClient;
    using System.IO;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace ConsoleApplication1
    {
        class Program
        {
            /// <summary>
            /// 打开连接
            /// </summary>
         
            static void Main(string[] args)
            {
                string dirp = @"C:UserssihangDesktop博鳌照片";           
                DirectoryInfo mydir = new DirectoryInfo(dirp);
                StringBuilder sb = new StringBuilder();
                foreach (FileInfo fi in mydir.GetFiles())
                {
                    string thumbimg = "/uploadfiles/article/150403/" + fi.Name;
                    string title = (fi.Name).Substring(0, fi.Name.LastIndexOf("."));
                    string date = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
                    string web = "新华网";
                    string infoimg = "/uploadfiles/article/150403/" + fi.Name;
                    //Console.WriteLine(thumbimg);
                    //Console.WriteLine(title);
                    //Console.WriteLine(date);
                    //Console.WriteLine(web);
                    //Console.WriteLine(infoimg);
                    //Console.WriteLine("/uploadfiles/article/150403/" + fi.Name);
                    //Console.WriteLine((fi.Name).Substring(0, fi.Name.LastIndexOf(".")));
                    //Console.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
                    //Console.WriteLine("新华网");
                    //sd += "insert into cc ;";
                    sb.Append("insert into jcms_normal_content (Img,Title,AddDate,CustomField05,CustomField04,ChannelId,ClassId,IsPass,IsImg,ReadGroup,Module,TemplateId) values ('" + thumbimg + "','" + title + "','" + date + "','" + web + "','" + infoimg + "','2','12','1','1','-1','Picture','1011');
    ");
                }
    
                Console.WriteLine(sb.ToString());
                //Console.ReadLine();
            }
        }
    }

    这是将桌面上博鳌照片的文件夹里的所有图片路径及图片名称作为标题保存到对应的字段,并将sql脚本输出到cmd窗口中去了

    示例2:

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Windows.Forms;
    using System.IO;
    
    namespace WindowsFormsApplication1
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }
    
            private void button1_Click(object sender, EventArgs e)
            {
    
                string dirv = @"D:videoysxs";
                DirectoryInfo mydir = new DirectoryInfo(dirv);
                StringBuilder sb = new StringBuilder();
                foreach (FileInfo fi in mydir.GetFiles())
                {
                    string title = (fi.Name).Substring(0, fi.Name.LastIndexOf("."));
                    string date = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
                    //写法1
                    string filepath = @"D:videoysxs" + fi.Name;
                    sb.Append("insert into jcms_normal_content (Title,AddDate,ClassId,Editor,IsPass,ReadGroup,Module,TemplateId,CustomField01) values ('" + title + "','" + date + "','8','admin','1','-1','news','11','" + filepath + "');
    ");
                    textBox1.Text = sb.ToString();
    
    
                    //写法2
                    //string s = @"insert into jcms_normal_content ((Title,AddDate,ClassId,Editor,IsPass,ReadGroup,Module,TemplateId,CustomField01)) values ('{0}','" + date + "','8','admin','1','-1','news','11','D:\video\ysxs\{1}');";
                    //textBox1.Text += string.Format(s, fi.Name.Replace(".txt", ""), fi.Name) + "
    "; 
                }
    
            }
        }
    }

    新建winform控制台程序,这样就能将sql输出到textbox1文本框中去了。

  • 相关阅读:
    经典数组排序方法------快速排序法
    经典数组排序方法------选择排序法,冒泡排序法
    两个非常好的bootstrap模板,外送大话设计模式!
    商场促销-策略模式(和简单工厂模式很像的哇) C#
    代码无错就是优?简单工厂模式 C#
    大话设计模式(C#)
    马加爵遗书 VS 药家鑫遗书
    GIT 常用命令
    Random快速产生相同随机数的原因及解决方案
    JSON WEB TOKEN,简单谈谈TOKEN的使用及在C#中的实现
  • 原文地址:https://www.cnblogs.com/shy1766IT/p/4662958.html
Copyright © 2011-2022 走看看