vb.net,读取问文件夹内的图片和视频,按照exif的拍摄日期分类到不同年月的文件夹内,如果没有exif信息则采用文件的修改日期,每行注释


好的,这里是一个 VB.NET 脚本,用于读取指定文件夹内的图片和视频,并根据 EXIF 拍摄日期或文件修改日期将其分类到不同年月的文件夹内。 ```vb Imports System.IO Imports System.Drawing.Imaging Module Module1 Sub Main() Dim sourceFolder As String = "C:\Path\To\Your\Folder" ' 源文件夹路径 Dim targetFolder As String = "C:\Path\To\Target\Folder" ' 目标文件夹路径 ' 获取源文件夹中的所有图片和视频文件 Dim files As String() = Directory.GetFiles(sourceFolder, "*.*", SearchOption.AllDirectories) For Each file In files Try ' 获取文件扩展名 Dim extension As String = Path.GetExtension(file).ToLower() ' 检查是否为图片或视频文件 If IsImageOrVideo(extension) Then ' 获取文件的拍摄日期或修改日期 Dim dateTaken As DateTime = GetDateTaken(file) ' 创建目标文件夹路径 Dim yearMonthFolder As String = Path.Combine(targetFolder, dateTaken.ToString("yyyy-MM")) ' 如果目标文件夹不存在,则创建 If Not Directory.Exists(yearMonthFolder) Then Directory.CreateDirectory(yearMonthFolder) End If ' 移动文件到目标文件夹 Dim targetFilePath As String = Path.Combine(yearMonthFolder, Path.GetFileName(file)) File.Move(file, targetFilePath) End If Catch ex As Exception Console.WriteLine($"处理文件 {file} 时出错: {ex.Message}") End Try Next Console.WriteLine("文件分类完成!") End Sub Function IsImageOrVideo(ByVal extension As String) As Boolean ' 定义支持的图片和视频扩展名 Dim imageExtensions As String() = {".jpg", ".jpeg", ".png", ".bmp", ".gif", ".tiff"} Dim videoExtensions As String() = {".mp4", ".avi", ".mov", ".wmv", ".mkv"} ' 检查文件扩展名是否在支持的列表中 Return imageExtensions.Contains(extension) OrElse videoExtensions.Contains(extension) End Function Function GetDateTaken(ByVal filePath As String) As DateTime ' 尝试从 EXIF 中获取拍摄日期 Using img As Image = Image.FromFile(filePath) Dim propertyItem As PropertyItem = img.GetPropertyItem(36867) ' EXIF DateTimeOriginal 标签 If propertyItem IsNot Nothing Then Dim dateStr As String = Encoding.UTF8.GetString(propertyItem.Value).Trim(Chr(0)) Return DateTime.Parse(dateStr) End If End Using ' 如果没有 EXIF 信息,则使用文件的修改日期 Return File.GetLastWriteTime(filePath) End Function End Module ``` 额外需要注意的逻辑点: 1. 错误处理:在实际应用中,文件可能因为各种原因无法读取或移动,建议增加更详细的错误处理机制,比如记录日志或跳过有问题的文件。 2. 性能优化:如果文件数量较多,可以考虑使用多线程或异步处理来提高效率。 3. 用户交互:可以添加一些用户交互功能,比如提示用户选择源文件夹和目标文件夹,或者显示进度条。 [2024-12-06 13:17:56 | AI写代码神器 | 736点数解答]
- 帮我写一个批处理文件,内容如下: 1、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中p=的值改为"参数表.xlsx"中c列对应的值; 2、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中t=的值改为"参数表.xlsx"中b列对应的值; 3、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中s=的值改为"参数表.xlsx"中d列对应的值; 如: 参数表.xlsx中a列a1,a2,a3;b列1.5,2,3;c列为10,20,30;d列100,101,102; 文件.txt中的行 1:l p[54:a1] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=10,ed=1]; 2:l p[57:a2] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=11,ed=1]; 3:l p[67:a3] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=12,ed=1]; 文件.txt修改后为 1:l p[54(811点数解答 | 2024-12-05 12:58:37)256
- 帮我写一个批处理文件,内容如下: 1、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中p=的值改为"参数表.xlsx"中c列对应的值; 2、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中t=的值改为"参数表.xlsx"中b列对应的值; 3、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中s=的值改为"参数表.xlsx"中d列对应的值; 参数表.xlsx中a列a1,a2,a3;b列1.5,2,3;c列为10,20,30;d列100,101,102; 文件.txt数据 1:l p[54:a1] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=10,ed=1]; 2:l p[57:a2] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=11,ed=1]; 3:l p[67:a3] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=12,ed=1]; 文件.txt修改后数据 1:l p[54:a1(531点数解答 | 2024-12-05 13:20:42)253
- 帮我写一个批处理文件,内容如下: 1、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中p=的值改为"参数表.xlsx"中c列对应的值; 2、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中t=的值改为"参数表.xlsx"中b列对应的值; 3、如果在"参数表.xlsx"a列中的值找到与"文件.txt"中相同的值,则把此行中s=的值改为"参数表.xlsx"中d列对应的值; 参数表.xlsx中a列a1,a2,a3;b列1.5,2,3;c列为10,20,30;d列100,101,102; 文件.txt数据 1:l p[54:a1] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=10,ed=1]; 2:l p[57:a2] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=11,ed=1]; 3:l p[67:a3] 2000mm/sec cnt100 spot[sd=1,p=25,t=2.0,s=12,ed=1]; 文件.txt修改后数据 1:l p[54:a1(495点数解答 | 2024-12-05 13:22:26)228
- 题目描述 输入三个整数 x , y , z x,y,z, 如果 x x为奇数,输出 1 ∼ y 1∼y之间的所有数,如果 x x为偶数,输出 1 ∼ z 1∼z之间的所有数。 输入格式 输入包括一行,包含三个整数 x , y , z x,y,z,数字之间用空格隔开。 输出格式 输出包括一行 如果 x x为奇数,输出 1 ∼ y 1∼y之间的所有数,如果 x x为偶数,输出 1 ∼ z 1∼z之间的所有数,输出时,数与数之间用1个空格隔开。 input1 复制 1 10 5 output1 复制 1 2 3 4 5 6 7 8 9 10 input2 复制 4 20 4 output2 复制 1 2 3 4 样例解释 对于样例 1 1: x x是奇数, y = 10 y=10,因此输出 1 ∼ 10 1∼10。 对于样例 2 2: x x是偶数, z = 10 z=10,因此输出 1 ∼ 4 1∼4 。 c++ (391点数解答 | 2025-06-14 09:57:45)165
- 题目描述 输入三个整数 x , y , z x,y,z, 如果 x x为奇数,输出 1 ∼ y 1∼y之间的所有数,如果 x x为偶数,输出 1 ∼ z 1∼z之间的所有数。 输入格式 输入包括一行,包含三个整数 x , y , z x,y,z,数字之间用空格隔开。 输出格式 输出包括一行 如果 x x为奇数,输出 1 ∼ y 1∼y之间的所有数,如果 x x为偶数,输出 1 ∼ z 1∼z之间的所有数,输出时,数与数之间用1个空格隔开。 c++(372点数解答 | 2025-07-06 15:39:04)110
- pandas读取文件,文件某一列分组,条件为列数据字段中包含“一级”为一组,没有“一级”的为一组,将pandas读取到的文件按地市映射表分为各地市文件,再将这个文件当作邮件附件,邮件正文为某地市,有“一级”多少,没有“一级”多少,语言方向:Python,系统环境:Windows(459点数解答 | 2024-12-25 01:17:06)166
- 1.使用pandas库读取数据“data.csv”,展示其前5行数据。 2.对数据进行探索,查看数据类型、缺失值以及数据基本的数值统计详细信息。 3.对数据data日期格式数据做日期转换。 4.查看data**信息统计情况。 (1)查看发布**信息中所在城市city的岗位数量统计信息,统计**信息较多的前五名城市。 (2)保留学历是本科和大专的**信息. 0618220232 061822( (3)修改“district”列,如“高新区”,需要改成“成都-高新区” (4)找出"positionadvantage”职位优势这一列中有“双休”条件的**信息,在所有发布的**信息中的占比,保留2位小数。(5)根据“salary”工资列,新增最低工资和最高工资两列,列名分别设置为“最低工资”和“最高工资”,(如10k-30k,则最低 工资为10k,最高工资为20k) 5.对数据data作统计分析(642点数解答 | 2024-06-30 15:39:49)257
- 1.使用pandas库读取数据“data.csv”,展示其前5行数据。 2.对数据进行探索,查看数据类型、缺失值以及数据基本的数值统计详细信息。 3.对数据data日期格式数据做日期转换。 4.查看data**信息统计情况。 (1)查看发布**信息中所在城市city的岗位数量统计信息,统计**信息较多的前五名城市。 (2)保留学历是本科和大专的**信息. 0618220232 061822( (3)修改“district”列,如“高新区”,需要改成“成都-高新区” (4)找出"positionadvantage”职位优势这一列中有“双休”条件的**信息,在所有发布的**信息中的占比,保留2位小数。(5)根据“salary”工资列,新增最低工资和最高工资两列,列名分别设置为“最低工资”和“最高工资”,(如10k-30k,则最低 工资为10k,最高工资为20k) 5.对数据data作统计分析(1)统计分析各城市**数量分布图(2)**学历占比图 **学历占比图(3)通过**学历分析图,给出你对**发布情况的分析结论.(4)统计每一天发布的**数量图,按天来统计(提示:需要先将时间按每天来统(1539点数解答 | 2024-06-30 15:56:50)266
- 作为c#工程师,如何在.net(c# or vb.net)中如何取消一个窗体的关闭?(299点数解答 | 2023-11-09 17:47:17)201
- 作为c#工程师,如何在.net(c# or vb.net)如何启动另一个程序?(409点数解答 | 2023-11-09 17:47:25)219
- 作为c#工程师,在.net(c# or vb.net)中,appplication.exit 还是 form.close有什么不同?(332点数解答 | 2023-11-09 17:47:25)214
- 1.定义一个抽象类,并设计两个子类继承该抽象类,演示它们的使用。 具体过程为,定义一个类vehicle并将它声明为抽象类。在类vehicle中声明一个infoofwheels方法,返回值为字符串类型。创建两个类car和motorbike从vehicle类继承而来,并在这两个类中实现info0fwheels方法。在car类中,应当返回“四轮车”信息:而在motorbike类中,应当返回“双轮车”信息。创建另一个带main方法的测试类test,在该类中创建car和motorbike的实例,并在控制台分别显示它们返回的信息。(440点数解答 | 2024-06-06 23:18:54)223