@Echo Off Set /p yearmonthday=输入: 出生年月日 (例如 19970731) Set year=%yearmonthday:~0,4% Set monthday=%yearmonthday:~4,4% Set /a mod=%year%%%12 if %mod%==0 Echo 你属猴 if %mod%==1 Echo 你属鸡 if %mod%==2 Echo 你属狗 if %mod%==3 Echo 你属猪 if %mod%==4 Echo 你属鼠 if %mod%==5 Echo 你属牛 if %mod%==6 Echo 你属虎 if %mod%==7 Echo 你属兔 if %mod%==8 Echo 你属龙 if %mod%==9 Echo 你属蛇 if %mod%==10 Echo 你属马 if %mod%==11 Echo 你属羊 if "%monthday%" LEQ "0119" echo 魔蝎座 if "%monthday%" GEQ "0120" if "%monthday%" LEQ "0218" echo 水瓶座 if "%monthday%" GEQ "0219" if "%monthday%" LEQ "0320" echo 双鱼座 if "%monthday%" GEQ "0321" if "%monthday%" LEQ "0419" echo 白羊座 if "%monthday%" GEQ "0420" if "%monthday%" LEQ "0520" echo 金牛座 if "%monthday%" GEQ "0521" if "%monthday%" LEQ "0621" echo 双子座 if "%monthday%" GEQ "0622" if "%monthday%" LEQ "0722" echo 巨蟹座 if "%monthday%" GEQ "0723" if "%monthday%" LEQ "0822" echo 狮子座 if "%monthday%" GEQ "0823" if "%monthday%" LEQ "0922" echo 处女座 if "%monthday%" GEQ "0923" if "%monthday%" LEQ "1023" echo 天秤座 if "%monthday%" GEQ "1024" if "%monthday%" LEQ "1122" echo 天蝎座 if "%monthday%" GEQ "1222" echo 魔蝎座 Pause

时间: 2023-11-21 18:52:02 AIGC 浏览: 159
这是一段Windows批处理脚本代码,可以用于判断输入的出生年月日属于哪个生肖和星座。具体来说,程序首先通过Set命令获取输入的出生年月日并提取出年份和月日两个变量。然后通过取年份的余数来计算属于哪个生肖,并输出对应的结果。接着通过比较月日的大小来计算属于哪个星座,并输出对应的结果。最后程序通过Pause命令暂停,等待用户按下任意键结束程序。 需要注意的是,该脚本代码中的星座判断有一个小问题,即当月份为12月并且日期大于等于22日时会被判断为魔蝎座,而实际上应该是摩羯座。
相关问题

chcp 65001 @echo off setlocal enabledelayedexpansion for /f "tokens=2 delims==" %%a in ('wmic OS Get localdatetime /value') do set "dt=%%a" set "year=!dt:~0,4!" set "month=!dt:~4,2!" set "day=!dt:~6,2!" set output_folder=%YEAR%_%MONTH%_%DAY% if not exist "!output_folder!" mkdir "!output_folder!" for %%I in (*.m4a) do ( set "output_file=!output_folder!\%%~nI.mp3" ffmpeg -i "%%I" -acodec libmp3lame -q:a 0 "!output_file!" ) for %%I in (*.flac *.mp4) do ( set "output_file=!output_folder!\%%~nI.mp3" ffmpeg -i "%%I" -q:a 0 -map a "!output_file!" ) endlocal

<think>嗯,用户想要批量转换音频文件为MP3,并且按日期创建文件夹来整理。首先,我需要确定使用什么工具,用户提到了ffmpeg,这很好,因为ffmpeg确实支持多种音频格式的转换。接下来,我得考虑如何编写一个批处理脚本,在Windows环境下运行。 首先,得确保用户已经安装了ffmpeg,并且将其添加到系统路径中,这样在命令行里才能直接调用。如果用户没有安装的话,可能需要先下载并配置环境变量。不过用户可能已经知道这一点,所以暂时先假设ffmpeg可用。 然后,转换音频文件。基本命令应该是ffmpeg -i input.ext output.mp3,但可能需要调整比特率等参数。用户可能希望保持较高的音质,所以可以考虑设置比特率,比如使用-ab 192k来指定192kbps的比特率。 接下来是按日期创建文件夹。需要考虑的是音频文件的修改日期或者创建日期。通常,文件的修改日期更可靠,因为用户可能没有更改过创建日期。在Windows的批处理脚本中,可以使用for循环遍历文件,然后使用%~tF来获取文件的时间戳。不过,这个时间戳的格式可能因系统区域设置不同而有所变化,比如英文系统和中文系统的日期格式可能不同,这可能会导致解析错误。 比如,%~tF返回的日期格式可能是“yyyy-mm-dd”或者“dd/mm/yyyy”,这取决于系统设置。所以需要处理不同的日期格式,确保正确提取日期部分。或者,用户可能希望使用文件的创建日期,这时候可能需要使用其他方法,比如PowerShell命令,但批处理脚本可能不太方便。可能需要先统一处理日期格式的问题。 假设用户使用的是英文系统,日期格式为mm/dd/yyyy,那么可以使用for循环中的变量扩展来提取各部分。例如,将%~tF的第四个字段作为月份,第五个作为日期,第六个作为年份?或者可能需要分割字符串。或者,考虑使用wmic命令来获取文件的创建日期,这样可能更可靠,但wmic在批处理中使用起来比较复杂。 例如,使用wmic datafile where "name='filename'" get LastModified可以获取到文件的最后修改时间,格式是统一的一长串数字,比如YYYYMMDDHHMMSS.xxxxxx±UTC,这样处理起来会更方便,可以提取前八位作为日期。不过这种方法需要处理每个文件的路径转义问题,可能会比较麻烦,尤其是路径中包含空格或特殊字符时。 不过,如果用户只需要简单的按修改日期组织,而系统区域设置下的日期格式是固定的,可能可以这样做: 在for循环中,获取文件的修改日期,例如: for %%F in (*.wav *.flac) do ( set "fdate=%%~tF" ) 然后解析fdate变量。假设fdate的格式是“mm/dd/yyyy hh:mm AM/PM”,那么前10个字符可能是日期部分,需要分割成月、日、年。比如,将fdate的前部分分割为mm, dd, yyyy,然后组合成yyyy-mm-dd这样的格式作为文件夹名。 但不同的系统区域设置可能导致日期格式不同,比如有的可能是dd/mm/yyyy。这样直接分割可能会有问题。所以需要找到一个通用的方法。或者,使用PowerShell命令来获取标准化的日期格式,这样更可靠一些。比如在批处理中调用PowerShell命令来获取日期。 例如,可以使用如下方法: for %%F in (*.wav *.flac) do ( for /f "usebackq" %%D in (`powershell -command "(Get-Item '%%F').LastWriteTime.ToString('yyyy-MM-dd')"`) do ( set "folder=%%D" ) ) 这样,不管系统区域设置如何,PowerShell都能返回yyyy-MM-dd格式的日期。这可能更可靠,但需要用户允许运行PowerShell脚本,并且可能会稍微影响执行速度。 不过,用户可能更倾向于纯批处理解决方案,避免依赖PowerShell。所以可能需要处理不同的日期格式。或者,在脚本中先检测日期格式,然后相应地进行处理。但这样会增加脚本的复杂性。 假设用户接受使用PowerShell来获取标准日期,那么这部分可以写得比较简洁。否则,可能需要更复杂的字符串处理。 接下来,创建对应的文件夹。比如,如果输出目录是“output”,则在其中按日期创建子文件夹,如“output\2023-10-05”,然后将转换后的MP3文件放入其中。 然后,转换文件时,需要处理文件名中的空格,可能需要使用引号将输入和输出路径括起来。例如: ffmpeg -i "%%F" -ab 192k "output\!folder!\%%~nF.mp3" 这里需要注意延迟变量扩展的问题,因为在for循环中修改了folder变量,所以需要使用延迟扩展,即启用setlocal enabledelayedexpansion,并在访问变量时使用!folder!而不是%folder%。 另外,需要处理不同的输入格式,比如用户可能有.wav、.flac、.aac等文件,所以需要在for循环中包括这些扩展名。用户提到的是批量转换音频文件,所以可能需要通配符匹配多个格式,例如:*.wav *.flac *.aac等。 最后,整个脚本的大致流程是: 1. 遍历当前目录下所有的音频文件(指定扩展名)。 2. 对于每个文件,获取其最后修改日期,并格式化为yyyy-mm-dd。 3. 创建对应的输出文件夹(如果不存在)。 4. 使用ffmpeg转换文件为MP3,保存到对应的日期文件夹中。 在批处理脚本中,可能需要开启延迟扩展,使用for循环遍历文件,调用ffmpeg进行转换。 现在,将这些步骤写成脚本: 首先,设置变量: @echo off setlocal enabledelayedexpansion 然后,遍历所有支持的音频文件: for %%F in (*.wav *.flac *.aac *.ogg) do ( 对于每个文件,获取修改日期并格式化为yyyy-mm-dd。这里使用PowerShell: for /f "usebackq" %%D in (`powershell -command "(Get-Item '%%F').LastWriteTime.ToString('yyyy-MM-dd')"`) do ( set "folder=%%D" ) 然后创建文件夹: if not exist "output\!folder!\" ( mkdir "output\!folder!" ) 接着转换文件: ffmpeg -i "%%F" -ab 192k "output\!folder!\%%~nF.mp3" ) 但这里需要注意,如果用户没有安装PowerShell,或者执行策略限制,可能会出错。不过,Windows 10及以上版本通常都带有PowerShell,并且执行单条命令应该没问题。 另外,可能需要处理文件名中的特殊字符,比如空格,所以路径需要用引号括起来。 综合起来,整个脚本大致如下: @echo off setlocal enabledelayedexpansion for %%F in (*.wav *.flac *.aac *.ogg) do ( echo 正在处理文件: %%F for /f "usebackq" %%D in (`powershell -command "(Get-Item '%%F').LastWriteTime.ToString('yyyy-MM-dd')"`) do ( set "folder=%%D" ) if not exist "output\!folder!\" ( mkdir "output\!folder!" ) ffmpeg -hide_banner -loglevel error -i "%%F" -ab 192k -vn "output\!folder!\%%~nF.mp3" ) endlocal 这里添加了-hide_banner和-loglevel error来减少ffmpeg的输出,仅显示错误信息。-vn参数确保只处理音频流,避免可能的视频流干扰。 需要注意的是,转换参数可能需要根据用户需求调整,比如音频编码器选择(例如使用libmp3lame),但ffmpeg默认会根据输出文件扩展名自动选择编码器,所以指定输出为.mp3应该足够。不过,有些情况下可能需要明确指定编码器,比如添加-acodec libmp3lame。 因此,ffmpeg的命令可能需要调整为: ffmpeg -i "%%F" -acodec libmp3lame -ab 192k ... 但libmp3lame是默认的MP3编码器,所以可能不需要显式指定,不过为了保险起见,可以加上。 此外,如果输入文件有多个音频流,可能需要处理,但一般情况下音频文件只有一个流,所以可以忽略。 关于输出文件夹的结构,用户可能希望输出到当前目录下的output文件夹,按日期分类。如果有多个文件在同一天修改,它们会被放到同一个文件夹中。 现在,用户可能需要测试这个脚本,确保它能在他们的系统上运行。可能需要处理的一些问题包括: 1. ffmpeg路径问题:如果ffmpeg不在系统路径中,脚本会报错。用户需要确保ffmpeg已正确安装。 2. 文件权限:如果当前目录没有写入权限,可能无法创建output文件夹或子文件夹。 3. 日期格式问题:如果使用PowerShell命令获取日期,应该能返回正确的格式,但如果用户系统不允许执行PowerShell脚本,可能需要调整。 4. 文件名中的特殊字符:批处理脚本中的引号应该能处理带有空格的文件名,但需要测试。 最后,生成相关问题,可能包括如何调整音频质量,如何处理其他文件格式,如何按其他日期分类(如创建日期),或者如何并行处理以加快转换速度等。</think>以下是使用FFmpeg批量转换音频文件为MP3并按日期创建文件夹的Windows批处理脚本实现: ```batch @echo off setlocal enabledelayedexpansion for %%F in (*.wav *.flac *.aac *.ogg) do ( echo 正在处理文件: %%F for /f "usebackq" %%D in (`powershell -command "(Get-Item '%%F').LastWriteTime.ToString('yyyy-MM-dd')"`) do ( set "folder=%%D" ) if not exist "output\!folder!\" ( mkdir "output\!folder!" ) ffmpeg -hide_banner -loglevel error -i "%%F" -acodec libmp3lame -ab 192k -vn "output\!folder!\%%~nF.mp3" ) endlocal ``` ### 实现原理说明 1. **遍历音频文件**:支持.wav/.flac/.aac/.ogg格式文件,可根据需要修改扩展名列表 2. **获取修改日期**:使用PowerShell获取标准化的`YYYY-MM-DD`格式日期[^1] 3. **创建日期文件夹**:在`output`目录下按日期建立子文件夹 4. **转换音频格式**: - `-acodec libmp3lame`:指定MP3编码器 - `-ab 192k`:设置192kbps比特率(可调整为128k/256k等) - `-vn`:忽略视频流(纯音频转换) ### 使用说明 1. 将脚本保存为`convert.bat` 2. 与待转换音频文件放置在同一目录 3. 右键以管理员身份运行 4. 转换结果保存在`output`目录下的日期文件夹中

@echo off chcp 65001 >nul setlocal enabledelayedexpansion :: =============== 配置四組路徑 =============== :: 組1配置 set "source_path_1=\\10.90.88.38\PM_DataBase\F_Datas\DataBase\Cycle" set "target_path_1=D:\IOT\941\PM_DataBase\Cycle" :: 組2配置 set "source_path_2=\\10.90.88.38\PM_DataBase\F_Datas\DataBase\DRate" set "target_path_2=D:\IOT\941\PM_DataBase\DRate" :: 組3配置 set "source_path_3=\\10.90.88.148\March\Plasma_1\Datalog\Interval" set "target_path_3=D:\iot\941\PM_DataBase\Datalog\942YT-004" :: 組4配置 set "source_path_4=\\10.90.88.166\March\Plasma_1\Datalog\Interval" set "target_path_4=D:\iot\941\PM_DataBase\Datalog\942YT-005" :: ========================================== :: 獲取當前日期(兼容性更好的方法) for /f "tokens=2 delims==" %%a in ('wmic os get localdatetime /value ^| findstr "LocalDateTime"') do set "now=%%a" if "%now%"=="" ( for /f "tokens=1-3 delims=/ " %%a in ("%date%") do ( set "current_year=%%c" set "current_month=%%b" set "current_day=%%a" ) set "current_date=!current_year!!current_month!!current_day!" ) else ( set "current_date=!now:~0,8!" ) :: 計算7天前的日期(YYYYMMDD格式) set /a "past_date=1%current_date% - 100000000 - 7" set "past_date=!past_date:~1!" echo 當前日期: !current_date! echo 7天前日期: !past_date! :: 處理四組路徑 for /l %%g in (1,1,4) do ( echo. echo ===== 正在處理組別 %%g ===== :: 動態獲取當前組的變量值 set "source_path=!source_path_%%g!" set "target_path=!target_path_%%g!" set "flag_file=!target_path!\.copy_completed_%%g" :: 檢查源路徑是否存在 if not exist "!source_path!\" ( echo 錯誤:組別 %%g 的源路徑不存在! echo 跳過此組操作... goto :next_group ) :: 創建目標目錄(如果不存在) if not exist "!target_path!\" ( echo 正在創建目標目錄... mkdir "!target_path!" ) :: =============== 新增文件类型处理 =============== :: 定义需要复制的文件类型(.mdb 和 .csv) set "file_types=*.mdb *.csv" :: ============================================== :: 執行複製操作 if not exist "!flag_file!" ( echo 首次執行 - 開始全量複製... xcopy "!source_path!\%%t" "!target_path!\" /I /Y >nul echo. > "!flag_file!" echo 全量複製完成!共複製以下文件: dir /b "!target_path!\%%t" ) else ( echo 增量複製模式 - 只複製最近七天內的新文件或更新文件... set file_count=0 :: 使用robocopy進行精確的日期過濾 robocopy "!source_path!" "!target_path!" *.mdb /maxage:7 /xx /is /njh /njs /ndl /nc /ns /np >nul if errorlevel 1 ( for /f "delims=" %%f in ('robocopy "!source_path!" "!target_path!" *.mdb /maxage:7 /xx /is /l /njh /njs /ndl /nc /ns /np') do ( if "%%f" neq "" ( echo 複製文件: %%~nxf set /a file_count+=1 ) ) ) if !file_count! equ 0 ( echo 沒有新增或更新的文件(最近七天內) ) else ( echo 共複製 !file_count! 個文件(最近七天內) ) ) :next_group echo ===== 組別 %%g 處理完成 ===== ) echo. echo 所有組別操作執行完畢 pause 修改後的代碼對於路徑34中的.csv文件並沒有複製

<think> 我们注意到用户反馈组3和组4的.csv文件没有被复制。检查修改后的代码发现两个问题: 1. 在全量复制部分(首次执行),使用了`xcopy "!source_path!\%%t"`,但这里的`%%t`是在一个未展开的循环变量。而在修改后的代码中,虽然定义了`file_types`,但在全量复制部分并没有循环处理每种文件类型。 2. 在增量复制部分,仍然只复制了`*.mdb`文件,没有使用`file_types`变量。 因此,我们需要修正这两个部分: 全量复制部分:应该遍历`file_types`中的每个文件类型,分别执行xcopy。 增量复制部分:应该使用`robocopy`同时复制`file_types`中定义的所有文件类型。 以下是修正后的代码段(仅修改了复制操作部分): 注意:原代码中全量复制部分直接使用了`%%t`,但没有循环。增量复制部分仍然写死了`*.mdb`。 修正步骤: 1. 在全量复制部分,添加一个循环,遍历`file_types`中的每个模式(即*.mdb和*.csv)。 2. 在增量复制部分,将`robocopy`命令中的文件类型由`*.mdb`改为`!file_types!`。 具体修改如下: 替换全量复制部分的代码(从`if not exist "!flag_file!" (`到对应的`else`之前): ```batch if not exist "!flag_file!" ( echo 首次執行 - 開始全量複製... REM 循环处理每种文件类型 for %%t in (!file_types!) do ( xcopy "!source_path!\%%t" "!target_path!\" /I /Y >nul ) echo. > "!flag_file!" echo 全量複製完成!共複製以下文件: REM 显示每种文件类型的文件 for %%t in (!file_types!) do ( dir /b "!target_path!\%%t" ) ) else ( ``` 替换增量复制部分的robocopy命令: 原代码中增量复制部分有两处`robocopy`命令:一处是实际复制操作(`robocopy ... >nul`),另一处是用于列出文件的模拟操作(在`for /f`循环中)。这两处都需要将`*.mdb`改为`!file_types!`。 修改增量复制部分: ```batch robocopy "!source_path!" "!target_path!" !file_types! /maxage:7 /xx /is /njh /njs /ndl /nc /ns /np >nul if errorlevel 1 ( for /f "delims=" %%f in ('robocopy "!source_path!" "!target_path!" !file_types! /maxage:7 /xx /is /l /njh /njs /ndl /nc /ns /np') do ( ``` 因此,完整修改后的代码段为(从`for /l %%g in (1,1,4) do (`循环内): ```batch for /l %%g in (1,1,4) do ( echo. echo ===== 正在處理組別 %%g ===== :: 動態獲取當前組的變量值 set "source_path=!source_path_%%g!" set "target_path=!target_path_%%g!" set "flag_file=!target_path!\.copy_completed_%%g" :: 檢查源路徑是否存在 if not exist "!source_path!\" ( echo 錯誤:組別 %%g 的源路徑不存在! echo 跳過此組操作... goto :next_group ) :: 創建目標目錄(如果不存在) if not exist "!target_path!\" ( echo 正在創建目標目錄... mkdir "!target_path!" ) :: =============== 新增文件类型处理 =============== :: 定义需要复制的文件类型(.mdb 和 .csv) set "file_types=*.mdb *.csv" :: ============================================== :: 執行複製操作 if not exist "!flag_file!" ( echo 首次執行 - 開始全量複製... for %%t in (!file_types!) do ( xcopy "!source_path!\%%t" "!target_path!\" /I /Y >nul ) echo. > "!flag_file!" echo 全量複製完成!共複製以下文件: for %%t in (!file_types!) do ( dir /b "!target_path!\%%t" ) ) else ( echo 增量複製模式 - 只複製最近七天內的新文件或更新文件... set file_count=0 :: 使用robocopy進行精確的日期過濾 robocopy "!source_path!" "!target_path!" !file_types! /maxage:7 /xx /is /njh /njs /ndl /nc /ns /np >nul if errorlevel 1 ( for /f "delims=" %%f in ('robocopy "!source_path!" "!target_path!" !file_types! /maxage:7 /xx /is /l /njh /njs /ndl /nc /ns /np') do ( if "%%f" neq "" ( echo 複製文件: %%~nxf set /a file_count+=1 ) ) ) if !file_count! equ 0 ( echo 沒有新增或更新的文件(最近七天內) ) else ( echo 共複製 !file_count! 個文件(最近七天內) ) ) :next_group echo ===== 組別 %%g 處理完成 ===== ) ``` 这样修改后,全量复制和增量复制都会处理`.mdb`和`.csv`文件。 注意:由于组3和组4的源路径中可能没有.mdb文件,只有.csv文件,所以之前只复制.mdb会导致.csv被忽略。现在同时复制两种文件类型,应该可以正常工作。 另外,在增量复制部分,我们使用`robocopy`同时复制两种文件类型,并且只复制7天内的文件。 请用户测试修改后的代码。 §§相关问题§§ 1. 如果某些组需要复制的文件类型不同(如组1和组2需要.mdb和.csv,而组3和组4需要.csv和.txt),应如何修改脚本以实现按组配置文件类型? 2. 如何调整脚本以支持按文件类型设置不同的保留天数(例如.mdb文件保留7天,.csv文件保留30天)? 3. 在复制过程中,如果遇到文件名中包含空格的情况,现有脚本是否能正确处理?如何增强脚本的健壮性? 4. 如何添加错误处理机制,以便在复制失败时记录错误并继续执行下一组? 5. 如何优化脚本以避免在目标目录不存在时创建多层目录(即如果目标路径的多级目录都不存在,如何确保成功创建)? </think> 在您的代码中,路径3和4的.csv文件没有复制是因为两个关键问题: 1. **全量复制部分**:使用了未定义的变量 `%%t`,应该改为遍历 `file_types` 2. **增量复制部分**:ROBOCOPY命令仍只复制 `*.mdb`,没有使用 `!file_types!` 变量 以下是完整的修复方案: ```batch @echo off chcp 65001 >nul setlocal enabledelayedexpansion :: ...(配置路径部分保持不变)... :: 獲取當前日期(兼容性更好的方法) for /f "tokens=2 delims==" %%a in ('wmic os get localdatetime /value ^| findstr "LocalDateTime"') do set "now=%%a" if "%now%"=="" ( for /f "tokens=1-3 delims=/ " %%a in ("%date%") do ( set "current_year=%%c" set "current_month=%%b" set "current_day=%%a" ) set "current_date=!current_year!!current_month!!current_day!" ) else ( set "current_date=!now:~0,8!" ) :: 計算7天前的日期(YYYYMMDD格式) set /a "past_date=1%current_date% - 100000000 - 7" set "past_date=!past_date:~1!" echo 當前日期: !current_date! echo 7天前日期: !past_date! :: 處理四組路徑 for /l %%g in (1,1,4) do ( echo. echo ===== 正在處理組別 %%g ===== :: 動態獲取當前組的變量值 set "source_path=!source_path_%%g!" set "target_path=!target_path_%%g!" set "flag_file=!target_path!\.copy_completed_%%g" :: 檢查源路徑是否存在 if not exist "!source_path!\" ( echo 錯誤:組別 %%g 的源路徑不存在! echo 跳過此組操作... goto :next_group ) :: 創建目標目錄(如果不存在) if not exist "!target_path!\" ( echo 正在創建目標目錄... mkdir "!target_path!" ) :: =============== 修正文件类型处理 =============== :: 定义需要复制的文件类型(.mdb 和 .csv) set "file_types=*.mdb *.csv" :: ============================================== :: 執行複製操作 if not exist "!flag_file!" ( echo 首次執行 - 開始全量複製... :: 修复点1:遍历所有文件类型 for %%t in (!file_types!) do ( xcopy "!source_path!\%%t" "!target_path!\" /I /Y >nul ) echo. > "!flag_file!" echo 全量複製完成!共複製以下文件: :: 修复点2:显示所有文件类型 for %%t in (!file_types!) do ( dir /b "!target_path!\%%t" ) ) else ( echo 增量複製模式 - 只複製最近七天內的新文件或更新文件... set file_count=0 :: 修复点3:ROBOCOPY使用所有文件类型 robocopy "!source_path!" "!target_path!" !file_types! /maxage:7 /xx /is /njh /njs /ndl /nc /ns /np >nul if errorlevel 1 ( for /f "delims=" %%f in ('robocopy "!source_path!" "!target_path!" !file_types! /maxage:7 /xx /is /l /njh /njs /ndl /nc /ns /np') do ( if "%%f" neq "" ( echo 複製文件: %%~nxf set /a file_count+=1 ) ) ) if !file_count! equ 0 ( echo 沒有新增或更新的文件(最近七天內) ) else ( echo 共複製 !file_count! 個文件(最近七天內) ) ) :next_group echo ===== 組別 %%g 處理完成 ===== ) echo. echo 所有組別操作執行完畢 pause ``` ### 主要修复点: 1. **全量复制修复**: - 添加了 `for %%t in (!file_types!)` 循环处理所有文件类型 - 移除了无效的 `%%t` 引用 2. **增量复制修复**: - 将 `robocopy` 命令中的 `*.mdb` 改为 `!file_types!` - 确保同时处理 .mdb 和 .csv 文件 3. **文件列表显示修复**: - 使用循环显示所有文件类型的复制结果 ### 测试建议: 1. 首次运行时观察全量复制是否包含.csv文件 2. 增量复制时检查是否同时复制新创建的.mdb和.csv文件 3. 验证路径3和4的网络共享访问权限
阅读全文

相关推荐

@echo off setlocal enabledelayedexpansion chcp 65001 >nul title ApacheBlockPerMin :: ------------------------------------------------------------ :: 运行日志(与脚本同目录 debug.log) set "debugLog=%~dp0debug.log" :: ========== 配置 ========== set "logDir=C:\xampp\apache\logs" set "threshold=10" set "scanInterval=60" set "blockList=C:\Users\Administrator\Desktop\blocked_ips.txt" :: ========================== :loop echo [%date% %time%] ===== loop ===== echo [%date% %time%] ===== loop ===== >> "%debugLog%" :: ---------- 检查管理员 ---------- net session >nul 2>&1 || ( echo [ERR] 需要以管理员身份运行 echo [%date% %time%] [ERR] 需要以管理员身份运行 >> "%debugLog%" pause exit /b 1 ) :: ---------- 确定日志文件 ---------- set "logFile=%logDir%\access.log" if exist "%logDir%\access_log.%date:~0,4%-%date:~5,2%-%date:~8,2%.log" ( set "logFile=%logDir%\access_log.%date:~0,4%-%date:~5,2%-%date:~8,2%.log" ) echo [%date% %time%] [INFO] 使用日志文件: %logFile% echo [%date% %time%] [INFO] 使用日志文件: %logFile% >> "%debugLog%" :: ---------- 生成上一分钟键(中文月份,适用于 CLF 格式) ---------- for /f %%t in ('powershell -NoLogo -NoProfile -Command ^ "$culture = New-Object System.Globalization.CultureInfo('zh-CN'); ^ (Get-Date).AddMinutes(-1).ToString(''dd/MMM/yyyy:HH:mm'', $culture)"') do ( set "minStr=%%t" ) echo [%date% %time%] [INFO] 扫描上一分钟 minStr=!minStr! echo [%date% %time%] [INFO] 扫描上一分钟 minStr=!minStr! >> "%debugLog%" :: ---------- 清空计数器 ---------- for /f "delims==" %%i in ('set found 2^>nul') do set "%%i=" :: ---------- 扫描日志 ---------- echo [%date% %time%] [DEBUG] 开始扫描日志文件: %logFile% echo [%date% %time%] [DEBUG] 开始扫描日志文件: %logFile% >> "%debugLog%" :: 用 findstr 先筛出可能的行,再用 for /f 逐行读取 findstr /r /c:"^[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]* .*\[[0-9][0-9]/[A-Za-z][a-z][a-z]/[0-9][0-9][0-9][0-9]:[0-9][0-9]:[0-9][0-9] \+[0-9][0-9][0-9][0-9]\]" "%logFile%" 2>nul | for /f "tokens=1,4 delims=[]:" %%a in ('more') do ( set "ip=%%a" set "ts=%%b" set "ts=!ts:~0,11!" if /i "!ts!"=="!minStr!" ( echo [DEBUG] 匹配成功 IP=!ip! 时间=!ts! echo [%date% %time%] [DEBUG] 匹配成功 IP=!ip! 时间=!ts! >> "%debugLog%" set /a found[!ip!]+=1 ) ) echo [%date% %time%] [DEBUG] 日志扫描完成 echo [%date% %time%] [DEBUG] 日志扫描完成 >> "%debugLog%" :: 输出匹配结果用于调试 for /f "tokens=1,2 delims==" %%i in ('set found 2^>nul') do ( echo [DEBUG] IP=%%i 计数=%%j echo [%date% %time%] [DEBUG] IP=%%i 计数=%%j >> "%debugLog%" ) :: ---------- 封禁 ---------- for /f "tokens=1,2 delims==" %%i in ('set found 2^>nul') do ( set "ip=%%i" set "cnt=%%j" if !cnt! geq %threshold% ( echo [%date% %time%] [ACTION] 封禁 !ip! !cnt!/min echo [%date% %time%] [ACTION] 封禁 !ip! !cnt!/min >> "%debugLog%" netsh advfirewall firewall show rule name="Block_!ip!" | findstr /i "规则名称" >nul if errorlevel 1 ( netsh advfirewall firewall add rule name="Block_!ip!" dir=in action=block remoteip=!ip! >nul if !errorlevel! neq 0 ( echo [%date% %time%] [ERR] 添加防火墙规则失败 echo [%date% %time%] [ERR] 添加防火墙规则失败 >> "%debugLog%" ) else ( echo !ip! >> "%blockList%" schtasks /create /sc once /st 23:59 /tn "Unblock_!ip!" ^ /tr "netsh advfirewall firewall delete rule name='Block_!ip!'" /f >nul if !errorlevel! neq 0 ( echo [%date% %time%] [ERR] 创建任务计划失败 echo [%date% %time%] [ERR] 创建任务计划失败 >> "%debugLog%" ) ) ) ) ) echo [%date% %time%] [DEBUG] 封禁操作完成 echo [%date% %time%] [DEBUG] 封禁操作完成 >> "%debugLog%" timeout /t %scanInterval% /nobreak >nul goto :loop 闪退

修改完整版的sql存储(积分兑换脚本),改写出可执行的shell和hive脚本。 积分兑换脚本: create procedure "rptdev"."sp_wjq_jf_value_dhfz_show"( in @data_date integer default cast("dateformat"("now"()-1,'yyyymmdd') as integer), in @is_run_flag1 integer default 1, in @is_run_flag2 integer default 10 ) on exception resume /****************************************************************** -- Purpose : 兑换积分分析报表 -- Auther: xxx -- Date : 20210923 *******************************************************************/ begin declare @stat_date varchar(8); --统计日期 declare @month_id integer; --统计月份 declare @month_first_date varchar(8); --统计月的第一天 declare @month_last_date varchar(8); --统计月的最后一天 declare @last_month_first_date varchar(8); --上月的第一天 declare @last_month_last_date varchar(8); --上月的最后一天 declare @last_month integer; --上月 declare @last_last_month integer; --上上月 declare @last_month_this_day varchar(8); --上月当天 declare @last_year_this_month integer; --上年当月 declare @this_year_first_month integer; --本年首月 declare @last_year_last_month integer; --上年尾月 set @stat_date = convert(varchar(8),@data_date); set @month_id = @data_date/100; set @month_first_date = "dateformat"(@data_date,'yyyymm01'); --统计月的第一天 set @month_last_date = "dateformat"("dateadd"("dd",-1,"dateformat"("dateadd"("mm",1,@data_date),'yyyymm01')),'yyyymmdd'); --统计月的最后一天 set @last_month_first_date = "dateformat"("dateadd"("mm",-1,@data_date),'yyyymm01'); --上月第一天 set @last_month_last_date = "dateformat"("dateadd"("dd",-1,"dateformat"("dateadd"("mm",1,@data_date),'yyyymm01')),'yyyymmdd'); set @last_month = cast("dateformat"("dateadd"("month",-1,@data_date),'yyyymm') as integer); --上月 set @last_last_month = cast("dateformat"("dateadd"("month",-2,@data_date),'yyyymm') as integer); --上上月 set @last_month_this_day = "dateformat"("dateadd"("mm",-1,convert(date,@data_date)),'yyyymmdd'); --上月当天 set @last_year_this_month = convert(integer,"dateformat"("dateadd"("yy",-1,@last_month_this_day),'yyyymm')); --上年当月 set @this_year_first_month = convert(integer,"dateformat"("dateadd"("yy",0,@data_date),'yyyy01')); --本年首月 set @last_year_last_month = cast("dateformat"(convert(integer,"dateformat"("dateadd"("yy",-1,@data_date),'yyyy1231')),'yyyymm') as integer); --上年尾月 set temporary option "conversion_error" = 'OFF'; set temporary option "Query_Temp_Space_Limit" = 0; --drop table if exists rpt_wjq_jf_value_dhfz_list;commit;

大家在看

recommend-type

AD597下载资料.zip

K型热电偶作为一种温度传感器,K型热电偶通常和显示仪表,记录仪表和电子调节器配套使用。K型热电偶可以直接测量各种生产中从0℃到1300℃范围的液体蒸汽和气体介质以及固体的表面温度。其优点是:测量精度高。因热电偶直接与被测对象接触,不受中间介质的影响。测量范围广。常用的热电偶从-50~+1600℃均可连续测量。构造简单,使用方便。热电偶通常是由两种不同的金属丝组成,而且不受大小和开头的限制,外有保护套管,用起来非常方便。具体温度对应电压有具体的分度表可供查阅。可以百度搜索K型热电偶分度表即可。
recommend-type

XCC.Mixer1.42.zip

很好用的红警 首先,确保你的Ra2(或YR)已经注册,然后运行XCC Mixer,请等待...他会自动读取你电脑的各个磁盘. 一、提取rules.ini文件 1、打开XCC MIXER 点左上角[文件],点[打开],进到红警目录,选择ra2.mix打开 2、双击local.mix进入这个子文件包 3、找到rules.ini文件,鼠标在它上面点右键,点提取文件 4、选择保存位置,一般指定红警目录 5、点保存即完成文件提取 二、如果要提取MOD的规则文件,则可打开它的MIX,找rules(md).ini通常在expand(md)**.mix 在左方框框类型(type)为text的文件里很快能找到它
recommend-type

RTC6715规格书

The RTC6715 is a highly integrated FM receiver intended for application on 5.8GHz band FM demodulation. This chip includes a low noise amplifier, mixer, IF amplifier, FM demodulator, AGC, audio demodulators, audio Amps and noise squelch. With RSSI voltage output, the instantaneous radio signal strength can be monitoring. RTC6715 is able to demodulate the FM modulated video and Stereo audio signals sourced from RTC6705 and separate the desired signal at the dedicated output pins. Both Stereo and Mono application are available on the chip.
recommend-type

LQ-675KT 680KII 690K 106KF 进纸传感器复位调整软件,以及详细方法

LQ-675KT 680KII 690K 106KF 进纸传感器复位调整软件,以及详细方法
recommend-type

OpenWrt-x86-64-22.03纯净版本固件

这是我自已编译的OpenWrt x86-64的固件。支持Intel AX 201无线网卡开启Master模式。 我也加入了AX 200和AX201网卡的驱动。应该也支持AX 200和AX 210无线网卡。只是我手上没多余的网卡,只测试过201网卡。

最新推荐

recommend-type

tock-nlp-admin-server-22.3.0-sources.jar

tock-nlp-admin-server-22.3.0-sources.jar
recommend-type

tock-bot-connector-teams-22.9.2.jar

tock-bot-connector-teams-22.9.2.jar
recommend-type

Node.js构建的运动咖啡馆RESTful API介绍

标题《sportscafeold:体育咖啡馆》指出了项目名称为“体育咖啡馆”,这个名字暗示了该项目可能是一个结合了运动和休闲主题的咖啡馆相关的网络服务平台。该项目运用了多种技术栈,核心的开发语言为JavaScript,这从标签中可以得到明确的信息。 从描述中可以提取以下知识点: 1. **Node.js**:体育咖啡馆项目使用了Node.js作为服务器端运行环境。Node.js是一个基于Chrome V8引擎的JavaScript运行环境,它能够使得JavaScript应用于服务器端开发。Node.js的事件驱动、非阻塞I/O模型使其适合处理大量并发连接,这对于RESTFUL API的构建尤为重要。 2. **Express Framework**:项目中使用了Express框架来创建RESTFUL API。Express是基于Node.js平台,快速、灵活且极简的Web应用开发框架。它提供了构建Web和移动应用的强大功能,是目前最流行的Node.js Web应用框架之一。RESTFUL API是一组遵循REST原则的应用架构,其设计宗旨是让Web服务通过HTTP协议进行通信,并且可以使用各种语言和技术实现。 3. **Mongoose ORM**:这个项目利用了Mongoose作为操作MongoDB数据库的接口。Mongoose是一个对象文档映射器(ODM),它为Node.js提供了MongoDB数据库的驱动。通过Mongoose可以定义数据模型,进行数据库操作和查询,从而简化了对MongoDB数据库的操作。 4. **Passport.js**:项目中采用了Passport.js库来实现身份验证系统。Passport是一个灵活的Node.js身份验证中间件,它支持多种验证策略,例如用户名和密码、OAuth等。它提供了标准化的方法来为用户登录提供认证,是用户认证功能的常用解决方案。 5. **版权信息**:项目的版权声明表明了Sportscafe 2015是版权所有者,这表明项目或其相关内容最早发布于2015年或之前。这可能表明该API背后有商业实体的支持或授权使用。 从【压缩包子文件的文件名称列表】中我们可以了解到,该文件的版本控制仓库使用的是“master”分支。在Git版本控制系统中,“master”分支通常用于存放当前可部署的稳定版本代码。在“master”分支上进行的更改通常都是经过测试且准备发布到生产环境的。 综上所述,我们可以知道体育咖啡馆项目是一个利用现代JavaScript技术栈搭建的后端服务。它包含了处理HTTP请求的Express框架、连接MongoDB数据库的Mongoose库和实现用户身份验证的Passport.js中间件。该项目可用于构建提供体育信息、咖啡馆菜单信息、预约服务等的Web应用或API服务,这为体育咖啡馆的营销、用户体验和数据管理提供了可能。 考虑到文档资料的提及,该项目的安装和API文档应该包含在项目资料中,可能在项目的README文件或其他说明文档中。对于项目的使用者或者开发者而言,这部分文档非常重要,因为它们可以提供详细的信息和指导,帮助用户快速部署和使用该API。 总结来说,这是一套针对体育咖啡馆相关业务的后端解决方案,它使用了流行的开源技术栈,可以灵活地应用于体育咖啡馆的网络服务中,如信息发布、在线预约、会员管理等。
recommend-type

【LNR优化与用户体验】:一文看透互操作优化如何提升用户感知

# 摘要 LNR(邻区关系优化)是提升移动通信网络性能与用户体验的关键技术。本文系统阐述了LNR优化的基本概念、理论基础与技术实现路径,构建了包括信道质量评估、干扰建模及关键性能指标分析在内的数学模型,并探讨了参数配置、邻区管理及AI与大数据在LNR优化中的应用。通过量化用户感知指标,分析了LNR优化对视频流畅度、页面加载速度及切换性能的实际改善效果,并结合典型场景验证了其优化成效。本文进一步展望了LNR技术在5G及未来网络中的发展趋势与技术挑战。
recommend-type

Java1.8 的编程语言、使用场景、版本号、厂商、是否开源、发行日期、终止日期、可替代产品、推荐产品是什么

以下是关于 **Java 1.8** 的全面信息汇总,涵盖其编程语言特性、使用场景、版本号、厂商、是否开源、发行日期、终止支持日期、可替代产品和推荐产品。 --- ## ✅ Java 1.8 综合信息表 | 项目 | 内容 | |------|------| | **编程语言** | Java | | **版本号** | Java 1.8(也称为 Java 8) | | **厂商** | Oracle、Adoptium、Amazon(Corretto)、Azul(Zulu)、Red Hat、IBM 等 | | **是否开源** | ✅ 是(OpenJDK 1.8 是开源的,Oracle
recommend-type

Java开发的教区牧民支持系统介绍

根据给定文件信息,下面将详细阐述相关知识点: ### 标题知识点 #### catecumenus-java: 教区牧民支持系统 - **Java技术栈应用**:标题提到的“catecumenus-java”表明这是一个使用Java语言开发的系统。Java是目前最流行的编程语言之一,广泛应用于企业级应用、Web开发、移动应用等,尤其是在需要跨平台运行的应用中。Java被设计为具有尽可能少的实现依赖,所以它可以在多种处理器上运行。 - **教区牧民支持系统**:从标题来看,这个系统可能面向的是教会管理或教区管理,用来支持牧民(教会领导者或牧师)的日常管理工作。具体功能可能包括教友信息管理、教区活动安排、宗教教育资料库、财务管理、教堂资源调配等。 ### 描述知识点 #### 儿茶类 - **儿茶素(Catechin)**:描述中提到的“儿茶类”可能与“catecumenus”(新信徒、教徒)有关联,暗示这个系统可能与教会或宗教教育相关。儿茶素是一类天然的多酚类化合物,常见于茶、巧克力等植物中,具有抗氧化、抗炎等多种生物活性,但在系统标题中可能并无直接关联。 - **系统版本号**:“0.0.1”表示这是一个非常初期的版本,意味着该系统可能刚刚开始开发,功能尚不完善。 ### 标签知识点 #### Java - **Java语言特点**:标签中明确提到了“Java”,这暗示了整个系统都是用Java编程语言开发的。Java的特点包括面向对象、跨平台(即一次编写,到处运行)、安全性、多线程处理能力等。系统使用Java进行开发,可能看重了这些特点,尤其是在构建可扩展、稳定的后台服务。 - **Java应用领域**:Java广泛应用于企业级应用开发中,包括Web应用程序、大型系统后台、桌面应用以及移动应用(Android)。所以,此系统可能也会涉及这些技术层面。 ### 压缩包子文件的文件名称列表知识点 #### catecumenus-java-master - **Git项目结构**:文件名称中的“master”表明了这是Git版本控制系统中的一个主分支。在Git中,“master”分支通常被用作项目的主干,是默认的开发分支,所有开发工作都是基于此分支进行的。 - **项目目录结构**:在Git项目中,“catecumenus-java”文件夹应该包含了系统的源代码、资源文件、构建脚本、文档等。文件夹可能包含各种子文件夹和文件,比如src目录存放Java源代码,lib目录存放相关依赖库,以及可能的build.xml文件用于构建过程(如Ant或Maven构建脚本)。 ### 结合以上信息的知识点整合 综合以上信息,我们可以推断“catecumenus-java: 教区牧民支持系统”是一个使用Java语言开发的系统,可能正处于初级开发阶段。这个系统可能是为了支持教会内部管理,提供信息管理、资源调度等功能。其使用Java语言的目的可能是希望利用Java的多线程处理能力、跨平台特性和强大的企业级应用支持能力,以实现一个稳定和可扩展的系统。项目结构遵循了Git版本控制的规范,并且可能采用了模块化的开发方式,各个功能模块的代码和资源文件都有序地组织在不同的子文件夹内。 该系统可能采取敏捷开发模式,随着版本号的增加,系统功能将逐步完善和丰富。由于是面向教会的内部支持系统,对系统的用户界面友好性、安全性和数据保护可能会有较高的要求。此外,考虑到宗教性质的敏感性,系统的开发和使用可能还需要遵守特定的隐私和法律法规。
recommend-type

LNR切换成功率提升秘籍:参数配置到网络策略的全面指南

# 摘要 LNR(LTE to NR)切换技术是5G网络部署中的关键环节,直接影
recommend-type

How to install watt toolkit in linux ?

安装 Watt Toolkit(原名 Steam++)在 Linux 系统上通常可以通过编译源码或者使用预编译的二进制文件来完成。Watt Toolkit 是一个开源工具,主要用于加速 Steam 平台的下载速度,支持跨平台运行,因此在 Linux 上也能够很好地工作。 ### 安装步骤 #### 方法一:使用预编译的二进制文件 1. 访问 [Watt Toolkit 的 GitHub 仓库](https://github.com/BeyondDimension/SteamTools) 并下载适用于 Linux 的最新版本。 2. 解压下载的压缩包。 3. 给予可执行权限: ```
recommend-type

PHP实现用户墙上帖子与评论的分享功能

根据给定文件信息,我们可以推导出与“userwallposts”相关的知识点。这里涉及的关键概念包括用户墙面墙(User Wall)、帖子(Posts)和评论(Comments),以及它们在编程语言PHP中的实现方式。用户墙是一种允许用户发布信息,并让他们的朋友或跟随者查看并参与讨论的功能,常见于社交网站。 ### 用户墙概念 用户墙类似于现实生活中的一面墙,用户可以在上面贴上“帖子”来分享自己的想法、照片、视频等信息。其他用户可以在这些帖子下面进行“评论”,类似于在墙上留言。这种互动方式构建了一个社区式的交流环境,增加了用户之间的互动性和参与感。 ### 用户墙的实现 在PHP中实现用户墙功能需要处理前端用户界面和后端服务器逻辑。前端负责展示用户墙、帖子和评论的界面,而后端则负责存储、检索和管理这些数据。 1. **前端实现**:前端可以使用HTML、CSS和JavaScript来构建用户墙的界面。使用AJAX技术可以让用户无需刷新页面即可提交和获取新的帖子和评论。此外,可能还会用到模板引擎(如Twig或Smarty)来动态生成页面内容。 2. **后端实现**:后端PHP代码将负责处理前端发送的请求,如帖子和评论的添加、删除和检索。数据库(如MySQL)将用于存储用户信息、帖子内容、评论以及它们之间的关联关系。 3. **数据库设计**: - 用户表(users):存储用户信息,例如用户名、密码(加密存储)、用户状态等。 - 帖子表(posts):存储帖子信息,例如帖子ID、帖子内容、发帖时间、所属用户ID等。 - 评论表(comments):存储评论信息,包括评论ID、评论内容、评论时间、所属帖子ID和用户ID等。 4. **PHP与数据库交互**:使用PDO(PHP Data Objects)或mysqli扩展来执行SQL语句与数据库进行交互。PDO提供了数据库访问的抽象层,可以连接多种数据库系统,而mysqli则针对MySQL进行了优化。 5. **安全性**: - 输入验证:为了防止SQL注入等安全问题,需要对用户输入进行验证和清理。 - 输出编码:在将数据输出到浏览器之前,应将特殊字符转换为HTML实体。 - 用户认证:用户登录系统时,应采取安全措施如使用会话管理(session management)和防止跨站请求伪造(CSRF)。 6. **功能实现细节**: - 发布帖子:用户输入帖子内容并提交,后端接收并存储到帖子表中。 - 显示帖子:从帖子表中检索所有帖子并展示在用户墙上,包括帖子标题、内容、发布时间和发帖人等信息。 - 发布评论:用户对特定帖子发表评论,后端接收评论信息并将其存储到评论表中。 - 显示评论:为每个帖子显示其下的所有评论,包括评论内容、时间、评论者等。 ### 开源项目实践 “userwallposts-master”暗示了可能存在一个与用户墙帖子和评论相关的开源项目或代码库。这个项目可能包含预设的代码和文件结构,允许开发者下载、安装和配置来创建他们自己的用户墙功能。开发人员可以使用这个项目作为起点,根据自己的需求进一步定制和扩展功能。 在实际开发过程中,还需要考虑系统的可扩展性和维护性。例如,可以设计RESTful API让前端和后端分离,或者使用现代的PHP框架(如Laravel、Symfony等)来简化开发流程和提高代码的组织性。 在总结上述内容后,我们可以了解到用户墙是社交平台中常见的一种功能,其核心功能包括发布帖子和评论。在PHP环境下实现这样的功能需要对前端界面和后端逻辑有深入的理解,以及对数据库设计和交互的安全性有一定的认识。开源项目如“userwallposts-master”可能提供了一个基础框架,帮助开发者快速构建和部署一个用户墙系统。
recommend-type

【LNR信令深度解析】:MR-DC双连接建立全过程技术揭秘

# 摘要 本文系统探讨了LNR信令与MR-DC双连接技术的基本原理、架构组成及其关键信令流程。深入分析了MR-DC的网络架构分类、核心网元功能、无线承载管理机制以及双连接建立过程中的关键信令交互路径。同时,文章解析了LNR信令消息的结构特征与关键字段,探讨了MR-DC场景下的性能评估指标与优化策略,包括信令压缩、负载均衡及节能调度机制。最后,文章展望了MR-DC技术在5G