1.软文推荐

2.软文推荐

3.软文推荐

目录: 1、怎样写脚本把windows服务改为手动? 2、如何使用dd备份数据文件头部和ASM磁盘头部 3、windows bat脚本怎么写 4、教你如何在win10下自动运行python程序脚本 5、在windows系统中做个自动删除过期文件的脚本但是不执行 怎样写脚本把windows服务改为手动?

编写一个批处理文件,按照下列命令实例进行操作:

net start "服务名" (开启服务)

net stop "服务名" (关闭服务)

如果启动的服务名是词组时,服务名称两边要加双引号。

sc config 服务名 start= demand //手动

sc condig 服务名 start= auto //自动

sc config 服务名 start= disabled //禁用

sc start 服务名

sc stop 服务名

参考:如何使用dd备份数据文件头部和ASM磁盘头部

在文件系统下用dd备份文件头部做测试

SQL select name from v$datafile;

NAME

--------------------------------------------------------------------------------

/oradata/upgr/system01.dbf

/oradata/upgr/sysaux01.dbf

/oradata/upgr/undotbs01.dbf

/oradata/upgr/users01.dbf

SQL

SQL set lines 156 pages 100

SQL col dd_backup_cmd for a156

SQL col dd_restore_cmd for a156

SQL select 'dd if='||name||' of=/backup/'||substr(name,instr(name,'/',-1)+1)||'.FH bs='||block_size||' count=2' dd_backup_cmd from v$datafile;

DD_BACKUP_CMD

--------------------------------------------------------------------------------

dd if=/oradata/upgr/system01.dbf of=/backup/system01.dbf.FH bs=8192 count=2

dd if=/oradata/upgr/sysaux01.dbf of=/backup/sysaux01.dbf.FH bs=8192 count=2

dd if=/oradata/upgr/undotbs01.dbf of=/backup/undotbs01.dbf.FH bs=8192 count=2

dd if=/oradata/upgr/users01.dbf of=/backup/users01.dbf.FH bs=8192 count=2

SQL select 'dd of='||name||' if=/backup/'||substr(name,instr(name,'/',-1)+1)||'.FH bs='||block_size||' count=2 conv=notrunc' dd_restore_cmd from v$datafile;

DD_RESTORE_CMD

------------------------------------------------------------------------------------------

dd of=/oradata/upgr/system01.dbf if=/backup/system01.dbf.FH bs=8192 count=2 conv=notrunc

dd of=/oradata/upgr/sysaux01.dbf if=/backup/sysaux01.dbf.FH bs=8192 count=2 conv=notrunc

dd of=/oradata/upgr/undotbs01.dbf if=/backup/undotbs01.dbf.FH bs=8192 count=2 conv=notrunc

dd of=/oradata/upgr/users01.dbf if=/backup/users01.dbf.FH bs=8192 count=2 conv=notrunc

SQL

[oracle@db1 ~]$ dd if=/oradata/upgr/system01.dbf of=/backup/system01.dbf.FH bs=8192 count=2

2+0 records in

2+0 records out

16384 bytes (16 kB) copied, 0.000412654 s, 39.7 MB/s

破坏数据文件头部

[oracle@db1 ~]$ dd if=/dev/zero of=/oradata/upgr/system01.dbf bs=8192 count=2 conv=notrunc

2+0 records in

2+0 records out

16384 bytes (16 kB) copied, 0.000434433 s, 37.7 MB/s

[oracle@db1 ~]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.4.0 Production on Thu Jun 16 15:23:33 2016

Copyright (c) 1982, 2013, Oracle. All rights reserved.

Connected to an idle instance.

SQL startup

ORACLE instance started.

Total System Global Area 313159680 bytes

Fixed Size 2252824 bytes

Variable Size 167776232 bytes

Database Buffers 138412032 bytes

Redo Buffers 4718592 bytes

Database mounted.

ORA-01157: cannot identify/lock data file 1 - see DBWR trace file

ORA-01110: data file 1: '/oradata/upgr/system01.dbf'

SQL shutdown abort

ORACLE instance shut down.

SQL exit

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

With the Partitioning, Data Mining and Real Application Testing options

恢复数据文件头部

[oracle@db1 ~]$ dd of=/oradata/upgr/system01.dbf if=/backup/system01.dbf.FH bs=8192 count=2 conv=notrunc

2+0 records in

2+0 records out

16384 bytes (16 kB) copied, 0.000574576 s, 28.5 MB/s

[oracle@db1 ~]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.4.0 Production on Thu Jun 16 15:24:32 2016

Copyright (c) 1982, 2013, Oracle. All rights reserved.

Connected to an idle instance.

SQL startup

ORACLE instance started.

Total System Global Area 313159680 bytes

Fixed Size 2252824 bytes

Variable Size 167776232 bytes

Database Buffers 138412032 bytes

Redo Buffers 4718592 bytes

Database mounted.

Database opened.

SQL exit

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

With the Partitioning, Data Mining and Real Application Testing options

[oracle@db1 ~]$

在ASM情况下用dd备份文件头部做测试

SQL select ' dd '||

2 ' if=/backup/'||e.group_kffxp||'_'||e.disk_kffxp||'_'||a.file_number||'.FH'||

3 ' of='||d.path||

4 ' bs='||c.allocation_unit_size||

5 ' seek='||e.au_kffxp||

6 ' count=1 conv=notrunc' dd_restore_cmd

7 from

8 v$asm_alias a,

9 v$asm_file b,

10 v$asm_diskgroup c,

11 v$asm_disk d,

12 x$kffxp e

13 where a.file_number=e.number_kffxp

14 and a.group_number=e.group_kffxp

15 and b.group_number=a.group_number

16 and d.group_number=c.group_number

17 and e.group_kffxp=d.group_number

18 and a.file_number=b.file_number

19 and d.disk_number=e.disk_kffxp

20 and a.system_created='Y'

21 and b.type='DATAFILE'

22 and e.xnum_kffxp=0

23 order by a.file_number

24 /

DD_RESTORE_CMD

--------------------------------------------------------------------------------------------

dd if=/backup/1_3_283.FH of=/dev/oracleasm/disks/ASMDISK7 bs=1048576 seek=21 count=1 conv=notrunc

dd if=/backup/1_4_285.FH of=/dev/oracleasm/disks/ASMDISK8 bs=1048576 seek=262 count=1 conv=notrunc

dd if=/backup/1_2_287.FH of=/dev/oracleasm/disks/ASMDISK6 bs=1048576 seek=266 count=1 conv=notrunc

dd if=/backup/1_1_288.FH of=/dev/oracleasm/disks/ASMDISK5 bs=1048576 seek=299 count=1 conv=notrunc

dd if=/backup/1_3_291.FH of=/dev/oracleasm/disks/ASMDISK7 bs=1048576 seek=163 count=1 conv=notrunc

SQL

SQL select ' dd'||

2 ' if='||d.path||

3 ' of=/backup/'||e.group_kffxp||'_'||e.disk_kffxp||'_'||a.file_number||'.FH'||

4 ' bs='||c.allocation_unit_size||

5 ' skip='||e.au_kffxp||

6 ' count=1' dd_backup_cmd

7 from

8 v$asm_alias a,

9 v$asm_file b,

10 v$asm_diskgroup c,

11 v$asm_disk d,

12 x$kffxp e

13 where a.file_number=e.number_kffxp

14 and a.group_number=e.group_kffxp

15 and b.group_number=a.group_number

16 and d.group_number=c.group_number

17 and e.group_kffxp=d.group_number

18 and a.file_number=b.file_number

19 and d.disk_number=e.disk_kffxp

20 and a.system_created='Y'

21 and b.type='DATAFILE'

22 and e.xnum_kffxp=0

23 order by a.file_number

24 /

DD_BACKUP_CMD

---------------------------------------------------------------------------------------------------------------

dd if=/dev/oracleasm/disks/ASMDISK7 of=/backup/1_3_283.FH bs=1048576 skip=21 count=1

dd if=/dev/oracleasm/disks/ASMDISK8 of=/backup/1_4_285.FH bs=1048576 skip=262 count=1

dd if=/dev/oracleasm/disks/ASMDISK6 of=/backup/1_2_287.FH bs=1048576 skip=266 count=1

dd if=/dev/oracleasm/disks/ASMDISK5 of=/backup/1_1_288.FH bs=1048576 skip=299 count=1

dd if=/dev/oracleasm/disks/ASMDISK7 of=/backup/1_3_291.FH bs=1048576 skip=163 count=1

SQL

备份ASM中数据文件头部

[oracle@ohs1 ~]$ dd if=/dev/oracleasm/disks/ASMDISK7 of=/backup/1_3_283.FH bs=1048576 skip=21 count=1

1+0 records in

1+0 records out

1048576 bytes (1.0 MB) copied, 0.00664794 seconds, 158 MB/s

破坏ASM中数据文件头部

[oracle@ohs1 ~]$ dd if=/dev/zero of=/dev/oracleasm/disks/ASMDISK7 seek=21 count=1 conv=notrunc bs=1M

1+0 records in

1+0 records out

1048576 bytes (1.0 MB) copied, 0.000517497 seconds, 2.0 GB/s

[oracle@ohs1 ~]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.3.0 Production on Thu Jun 16 14:58:53 2016

Copyright (c) 1982, 2011, Oracle. All rights reserved.

Connected to an idle instance.

SQL startup

ORACLE instance started.

Total System Global Area 318046208 bytes

Fixed Size 1344680 bytes

Variable Size 188746584 bytes

Database Buffers 121634816 bytes

Redo Buffers 6320128 bytes

Database mounted.

ORA-01122: database file 1 failed verification check

ORA-01110: data file 1: '+DATA_PGOLD/racdb/system01.dbf'

ORA-01210: data file header is media corrupt

SQL shut abort

ORACLE instance shut down.

SQL exit

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

恢复ASM中数据文件头部

[oracle@ohs1 ~]$ dd if=/backup/1_3_283.FH of=/dev/oracleasm/disks/ASMDISK7 bs=1048576 seek=21 count=1 conv=notrunc

1+0 records in

1+0 records out

1048576 bytes (1.0 MB) copied, 0.00153561 seconds, 683 MB/s

[oracle@ohs1 ~]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.3.0 Production on Thu Jun 16 15:00:08 2016

Copyright (c) 1982, 2011, Oracle. All rights reserved.

Connected to an idle instance.

SQL startup

ORACLE instance started.

Total System Global Area 318046208 bytes

Fixed Size 1344680 bytes

Variable Size 188746584 bytes

Database Buffers 121634816 bytes

Redo Buffers 6320128 bytes

Database mounted.

Database opened.

SQL select open_mode from v$database;

OPEN_MODE

--------------------

READ WRITE

SQL

生成备份数据文件头部所需要的dd脚本(数据库用户)

set lines 156 pages 100

col dd_backup_cmd for a156

col dd_restore_cmd for a156

select 'dd if='||name||' of=/backup/'||substr(name,instr(name,'/',-1)+1)||'.FH bs='||block_size||' count=2' dd_backup_cmd from v$datafile;

select 'dd of='||name||' if=/backup/'||substr(name,instr(name,'/',-1)+1)||'.FH bs='||block_size||' count=2 conv=notrunc' dd_restore_cmd from v$datafile;

生成备份ASM数据文件头部所需要的dd脚本(在GI用户下ASM实例)

set lines 156 pages 100

col dd_backup_cmd for a156

col dd_restore_cmd for a156

select ' dd'||

' if='||d.path||

' of=/backup/'||e.group_kffxp||'_'||e.disk_kffxp||'_'||a.file_number||'.FH'||

' bs='||c.allocation_unit_size||

' skip='||e.au_kffxp||

' count=1' dd_backup_cmd

from

v$asm_alias a,

v$asm_file b,

v$asm_diskgroup c,

v$asm_disk d,

x$kffxp e

where a.file_number=e.number_kffxp

and a.group_number=e.group_kffxp

and b.group_number=a.group_number

and d.group_number=c.group_number

and e.group_kffxp=d.group_number

and a.file_number=b.file_number

and d.disk_number=e.disk_kffxp

and a.system_created='Y'

and b.type='DATAFILE'

and e.xnum_kffxp=0

order by a.file_number

/

select ' dd '||

' if=/backup/'||e.group_kffxp||'_'||e.disk_kffxp||'_'||a.file_number||'.FH'||

' of='||d.path||

' bs='||c.allocation_unit_size||

' seek='||e.au_kffxp||

' count=1 conv=notrunc' dd_restore_cmd

from

v$asm_alias a,

v$asm_file b,

v$asm_diskgroup c,

v$asm_disk d,

x$kffxp e

where a.file_number=e.number_kffxp

and a.group_number=e.group_kffxp

and b.group_number=a.group_number

and d.group_number=c.group_number

and e.group_kffxp=d.group_number

and a.file_number=b.file_number

and d.disk_number=e.disk_kffxp

and a.system_created='Y'

and b.type='DATAFILE'

and e.xnum_kffxp=0

order by a.file_number

/

生成备份ASM磁盘头部所需要的dd脚本(在GI用户下ASM实例)

set lines 150

set pages 1000

select

'dd if='||path||

' of=/backup/'||substr(path,instr(path,'/',-1)+1)||'_'||group_number||'_'||disk_number||'.DH bs=1M count=100'

from v$asm_disk asm_header_backup

where header_status='MEMBER'

order by group_number,disk_number;

select 'dd if=/backup/'||substr(path,instr(path,'/',-1)+1)||'_'||group_number||'_'||disk_number||'.DH'||

' of='||path||' bs=1M count=100 conv=notrunc'

from v$asm_disk asm_header_restore

where header_status='MEMBER'

order by group_number,disk_number;

生成asmcmd cp命令(数据库用户下执行)

select 'asmcmd cp '||name||' /backup/'||substr(name,instr(name,'/',-1)+1) asmcmd_cp from v$controlfile

union all

select 'asmcmd cp '||name||' /backup/'||substr(name,instr(name,'/',-1)+1) from v$datafile

union all

select 'asmcmd cp '||member||' /backup/'||thread#||'_'||a.group#||'_'||substr(member,instr(member,'/',-1)+1)

from v$log a, v$logfile b where a.group# = b.group#;

ASMCMD_CP

--------------------------------------------------------------------------------

asmcmd cp +DATA_PGOLD/racdb/control01.ctl /backup/control01.ctl

asmcmd cp +DATA_PGOLD/racdb/control02.ctl /backup/control02.ctl

asmcmd cp +DATA_PGOLD/racdb/system01.dbf /backup/system01.dbf

asmcmd cp +DATA_PGOLD/racdb/sysaux01.dbf /backup/sysaux01.dbf

asmcmd cp +DATA_PGOLD/racdb/undotbs01.dbf /backup/undotbs01.dbf

asmcmd cp +DATA_PGOLD/racdb/users01.dbf /backup/users01.dbf

asmcmd cp +DATA_PGOLD/racdb/undotbs02.dbf /backup/undotbs02.dbf

asmcmd cp +DATA_PGOLD/racdb/redo02.log /backup/1_2_redo02.log

asmcmd cp +DATA_PGOLD/racdb/redo01.log /backup/1_1_redo01.log

asmcmd cp +DATA_PGOLD/racdb/redo03.log /backup/2_3_redo03.log

asmcmd cp +DATA_PGOLD/racdb/redo04.log /backup/2_4_redo04.log

11 rows selected.

SQL

然后执行以上命令即可

生成rman copy命令(数据库用户下执行)

select 'copy current controlfile to ''/tmp/'||substr(name,instr(name,'/',-1)+1)||''';' rman_copy from v$controlfile

union all

select 'copy datafile '||file#||' to ''/backup/'||substr(name,instr(name,'/',-1)+1)||''';' from v$datafile;

RMAN_COPY

--------------------------------------------------------------------------------

copy current controlfile to '/tmp/control01.ctl';

copy current controlfile to '/tmp/control02.ctl';

copy datafile 1 to '/backup/system01.dbf';

copy datafile 2 to '/backup/sysaux01.dbf';

copy datafile 3 to '/backup/undotbs01.dbf';

copy datafile 4 to '/backup/users01.dbf';

copy datafile 5 to '/backup/undotbs02.dbf';

7 rows selected.

SQL

然后使用rman这些以上命令

windows bat脚本怎么写

批处理之家

你就用记事本就可以编辑了。里面输入dos命令

最后,另存为*.bat的格式

【 echo 命令 】

打开回显或关闭请求回显功能,或显示消息。如果没有任何参数,echo 命令将显示当前回显设置。

语法

echo [{on|off}] [message]

Sample:@echo off / echo hello world

在实际应用中我们会把这条命令和重定向符号(也称为管道符号,一般用 ^)结合来实现输入一

些命令到特定的文件中。

【 rem 命令 】

注释命令,类似于在C语言中的/*--------*/,它并不会被执行,只是起一个注释的作用,便于别人阅读

和你自己日后修改。

:: 也具有rem的功能

但::和rem还是有区别的,当关闭回显时,rem和::后的内容都不会显示。但是当打开回显时,rem和rem

后的内容会显示出来,然而::后的内容仍然不会显示。

Rem Message

Sample:@Rem Here is the description.

【 pause 命令 】

暂停命令。运行 Pause 命令时,将显示下面的消息:

Press any key to continue. . .(或:请按任意键继续. . .)

Sample:

@echo off

:begin

copy G:*.* d:ack

echo 请插入另一张光盘...

pause

goto begin

在这个例子中,驱动器 G 中磁盘上的所有文件均复制到d:ack中。显示的注释提示您将另一张光盘

盘放入驱动器 G 时,pause 命令会使程序挂起,以便您更换光盘,然后按任意键继续处理。

【 call 命令 】

从一个批处理程序调用另一个批处理程序,并且不终止父批处理程序。call 命令接受用作调用目标的

标签。如果在脚本或批处理文件外使用 Call,它将不会在命令行起作用。

语法

call [[Drive:][Path] FileName ] [:label [arguments]]

参数

[Drive:}[Path] FileName

指定要调用的批处理程序的位置和名称。

【 start 命令 】

调用外部程序,所有的DOS命令和命令行程序都可以由start命令来调用。

如:start calc.exe 即可打开Windows的计算器。

常用参数:

MIN 开始时窗口最小化

SEPARATE 在分开的空间内开始 16 位 Windows 程序

HIGH 在 HIGH 优先级类别开始应用程序

REALTIME 在 REALTIME 优先级类别开始应用程序

WAIT 启动应用程序并等候它结束

parameters 这些为传送到命令/程序的参数

执行的应用程序是 32-位 GUI 应用程序时,CMD.EXE 不等应用程序终止就返回命令提示。如果在命令

脚本内执行,该新行为则不会发生。

【 goto 命令 】

跳转命令。程序指针跳转到指定的标签,从标签后的第一条命令开始继续执行批处理程序。

语法:goto label (label是参数,指定所要转向的批处理程序中的行。)

Sample:

if {%1}=={} goto noparms

if {%2}=={} goto noparms(如果这里的if、%1、%2你不明白的话,先跳过去,后面会有详细的解释

。)

@Rem check parameters if null show usage

:noparms

echo Usage: monitor.bat ServerIP PortNumber

goto end

标签的名字可以随便起,但是最好是有意义的字母啦,字母前加个:用来表示这个字母是标签,goto

命令就是根据这个:来寻找下一步跳到到那里。最好有一些说明这样你别人看起来才会理解你的意图啊。

【 set 命令 】

显示、设置或删除变量。

显示变量:set 或 set s 前者显示批处理当前已定义的所有变量及其值,后者显示所有以s开头的变量及值。

设置变量:set aa=abcd 此句命令便可向变量aa赋值abcd。如果变量aa已被定义,则aa的值被修改为abcd;若aa尚未定义,则此句命令即可定义新的变量aa,同时为变量aa赋予初始值abcd。

删除变量:set aa= 此句命令即可删除变量aa。若变量aa已被定义,则删除变量aa;若aa尚未定义,则此句命令为实质意义。

需要说明的是,批处理中的变量是不区分类型的,不需要像C语言中的变量那样还要区分int、float、char等。比如执行set aa=345后,变量aa的值既可以被视为数字345,也可以被视为字符串345。

set命令具有扩展功能,如用作交互输入、字符串处理、数值计算等,属于高级命令范畴。

[编辑本段]批处理符号简介

【 回显屏蔽 @ 】

表示不显示@后面的命令,在入侵过程中(例如使用批处理来格式化敌人的硬盘)自然不能让对方看到你使用的命令啦。

@用法举例:通过运行批处理文件对比pause和@pause命令即可明了@的效果。

【 重定向1 与 】

将输出信息重定向到指定的设备或文件。系统默认输出到显示器。

如:echo aaaaaa.txt 即可将本在显示器上显示的信息aaaaa输出到文件a.txt中,屏幕上没有任何显示。如果文件a.txt本来已经存在,该命令将首先擦除a.txt中的所有信息,然后写入信息aaaaa;若a.txt本来就不存在,该命令即可新建一个a.txt文件,并写入信息aaaaa。

echo aaaaaa.txt 类似于echo aaaaaa.txt。区别在于:如果a.txt本已存在,a.txt会擦除a.txt中的原有内容,而a.txt并不擦除原有内容,仅在a.txt文件的末尾添加信息aaaaa。a.txt不存在时,二者没有差别。

【 重定向2 】

将输入信息来源重定向为指定的设备或文件。系统默认从显示器读取输入信息。

重定向使用举例:

=========================================

@echo off

echo abcdefg——这是文件a.txt中的信息a.txt

echo 请任意输入字符,以回车结束:

set /p ifo=

cls

echo 【 从屏幕获得的输入信息 】

echo %ifo%

set /p ifo=a.txt

echo 【 从文件a.txt获得的输入信息 】

echo %ifo%

pausenul

=========================================

读者观察命令与输出即可体会到重定向的功能和效果。

【 管道符号 | 】

将管道符号前面命令的输出结果重定向输出到管道符号后面的命令中去,作为后面命令的输入。使用格式为:command_1|command_2

管道符号使用举例:

=========================================

@echo off

echo aaaaa.txt

del /p a.txt

pause

=========================================

@echo off

echo aaaaa.txt

echo y|del /p a.txt

pause

=========================================

对比以上两个批处理执行结果,读者即可明白管道符的用法和效果。

需要说明的是,上面del命令添加开关/p只是为了让读者明白管道符号的使用方法,实际删除文件时不加/p开关即可实现无提示直接删除。

【 转义符 ^ 】

将特殊符号转化为一般符号,即剥离特殊符号的特殊地位。特殊符号指:|

比如,如果我们想输出符号“”,直接用命令 echo 是不行的,必须修改为 echo ^ 。其余几个特殊符号类似需要有同样的处理。

转义字符使用举例:

=========================================

@echo off

echo aaaaa.txt

echo 第一句echo执行完毕

echo aaaa^a.txt

echo 第二句echo执行完毕

pause

=========================================

比较上面的两句echo,第一句echo将信息aaaa输出到了文件a.txt,而第二句echo则在直接屏幕上显示出aaaaa.txt

【 逻辑命令符 】

逻辑命令符包括:、、||

-它的作用是用来连接n个DOS命令,并把这些命令按顺序执行,而不管是否有命令执行失败;

-当前面的命令成功执行时,执行后面的命令,否则不执行;

||-当||前面的命令失败时,执行||后面的命令,否则不执行。

=========================================

@echo off

echo ^|^|

reg add HKCU /v try /f||echo **成功**

reg add HKCU1 /v try /f||echo **失败**

echo ^^

reg delete HKCU /v try /fecho **成功**

reg delete HKCU /v try /fecho **失败**

echo ^

reg delete HKCU /v try /fecho **成功**

reg delete HKCU /v try /fecho **失败**

pause

=========================================

执行reg add或reg delete后,系统会给出执行结果;我们通过echo命令也给出了“执行结果”。对比系统和我们自己给出的结果,既可以验证逻辑命令的判断机理。

[编辑本段]常用DOS命令释义

【 文件夹管理 】

cd 显示当前目录名或改变当前目录。

md 创建目录。

rd 删除一个目录。

dir 显示目录中的文件和子目录列表。

tree 以图形显示驱动器或路径的文件夹结构。

path 为可执行文件显示或设置一个搜索路径。

xcopy 复制文件和目录树。

【 文件管理 】

type 显示文本文件的内容。

copy 将一份或多份文件复制到另一个位置。

del 删除一个或数个文件。

move 移动文件并重命名文件和目录。(Windows XP Home Edition中没有)

ren 重命名文件。

replace 替换文件。

attrib 显示或更改文件属性。

find 搜索字符串。

fc 比较两个文件或两个文件集并显示它们之间的不同

【 网络命令 】

ping 进行网络连接测试、名称解析

ftp 文件传输

net 网络命令集及用户管理

telnet 远程登陆

ipconfig显示、修改TCP/IP设置

msg 给用户发送消息

arp 显示、修改局域网的IP地址-物理地址映射列表

【 系统管理 】

at 安排在特定日期和时间运行命令和程序

shutdown立即或定时关机或重启

tskill 结束进程

taskkill结束进程(比tskill高级,但WinXPHome版中无该命令)

tasklist显示进程列表(Windows XP Home Edition中没有)

sc 系统服务设置与控制

reg 注册表控制台工具

powercfg控制系统上的电源设置

对于以上列出的所有命令,在cmd中输入命令+/?即可查看该命令的帮助信息。如find /?

[编辑本段]语句结构释义

类似于C语言,批处理也有它的语句结构。批处理的语句结构主要有选择结构(if语句)、循环结构(for语句)等。

【 if语句(选择结构) 】

if语句实现条件判断,包括字符串比较、存在判断、定义判断等。通过条件判断,if语句即可以实现选择功能。

1、字符串比较

if语句仅能够对两个字符(串)是否相同、先后顺序进行判断等。其命令格式为:

IF [not] string1 compare-op string2 command1 [else command2]

其中,比较操作符compare-op有以下几类:

== - 等于

EQU - 等于

NEQ - 不等于

LSS - 小于

LEQ - 小于或等于

GTR - 大于

GEQ - 大于或等于

选择开关/i则不区分字符串大小写;选择not项,则对判断结果进行逻辑非。

字符串比较示例:

===============================================

@echo off

set str1=abcd1233

set str2=ABCD1234

if %str1%==%str2% (echo 字符串相同!) else (echo 字符串不相同!)

if /i %str1% LSS %str2% (echo str1^str2) else (echo str1^=str2)

echo.

set /p choice=是否显示当前时间?(y/n)

if /i not %choice% EQU n echo 当前时间是:%date% %time%

pausenul

===============================================

对于最后一个if判断,当我们输入n或N时的效果是一样的,都不会显示时间。如果我们取消开关/i,则输入N时,依旧会显示时间。

另外请注意一下几个细节:1-echo str1^str2和echo str1^=str2;2-echo.。

2、存在判断

存在判断的功能是判断文件或文件夹是否存在。其命令格式为:

IF [NOT] EXIST filename command1 [else command2]

===============================================

@echo off

if exist %0 echo 文件%0是存在的!

if not exist %~df0 (

echo 文件夹%~df0不存在!

) else echo 文件夹%~df0存在!

pausenul

===============================================

这里注意几个地方:

1-存在判断既可以判断文件也可以判断文件夹;

2-%0即代表该批处理的全称(包括驱动器盘符、路径、文件名和扩展类型);

3-%~df0是对%0的修正,只保留了其驱动器盘符和路径,详情请参考for /?,属高级批处理范畴;

4-注意if语句的多行书写,多行书写要求command1的左括号必须和if在同一行、else必须和command1的右括号同行、command2的左括号必须与else同行、command1和command2都可以有任意多行,即command可以是命令集。

3、定义判断

定义判断的功能是判断变量是否存在,即是否已被定义。其命令格式为:

IF [not] DEFINED variable command1 [else command2]

存在判断举例:

===============================================

@echo off

set var=111

if defined var (echo var=%var%) else echo var尚未定义!

set var=

if defined var (echo var=%var%) else echo var尚未定义!

pausenul

===============================================

对比可知,"set var="可以取消变量,收回变量所占据的内存空间。

4、结果判断

masm %1.asm

if errorlevel 1 pause edit %1.asm

link %1.obj

先对源代码进行汇编,如果失败则暂停显示错误信息,并在按任意键后自动进入编辑界面;否则用link程序连接生成的obj文件,这种用法是先判断前一个命令执行后的返回码(也叫错误码,DOS程序在运行完后都有返回码),如果和定义的错误码符合(这里定义的错误码为1),则执行相应的操作(这里相应的操作为pause edit %1.asm部分)。

另外,和其他两种用法一样,这种用法也可以表示否定。用否定的形式仍表达上面三句的意思,代码变为:

masm %1.asm

if not errorlevel 1 link %1.obj

pause edit %1.asm

【 for语句(循环结构) 】

for语句可以实现类似于C语言里面的循环结构,当然for语句的功能要更强大一点,通过不同的开关可以实现更多的功能。for语句有多个开关,不同开关将会实现不同的功能。

1、无开关

无开关的for语句能够对设定的范围内进行循环,是最基本的for循环语句。其命令格式为:

FOR %%variable IN (set) DO command

其中,%%variable是批处理程序里面的书写格式,在DOS中书写为%variable,即只有一个百分号(%);set就是需要我们设定的循环范围,类似于C语言里面的循环变量;do后面的command就是循环所执行的命令,即循环体。

无开关for语句举例:

===============================================

@echo off

for %%i in (a,"b c",d) do echo %%i

pausenul

===============================================

2、开关/L

含开关/L的for语句,可以根据set里面的设置进行循环,从而实现对循环次数的直接控制。其命令格式为:

FOR /L %%variable IN (start,step,end) DO command

其中,start为开始计数的初始值,step为每次递增的值,end为结束值。当end小于start时,step需要设置为负数。

含开关/L的for语句举例(创建5个文件夹):

===============================================

@echo off

for /l %%i in (1,2,10) do md %%i

pause

===============================================

上例将新建5个文件夹,文件夹名称依次为1、3、5、7、9。可以发现,%%i的结束值并非end的值10,而是不大于end的一个数。

3、开关/F

含开关/F的for语句具有最强大的功能,它能够对字符串进行操作,也能够对命令的返回值进行操作,还可以访问硬盘上的ASCII码文件,比如txt文档等。其命令格式为:

FOR /F ["options"] %%variable IN (set) DO command

其中,set为("string"、'command'、file-set)中的一个;options是(eol=c、skip=n、delims=xxx、tokens=x,y,m-n、usebackq)中的一个或多个的组合。各选项的意义参见for /f。一般情况下,使用较多的是skip、tokens、delims三个选项。

含开关/F的for语句举例:

===============================================

@echo off

echo **No Options:

for /f %%a in ("1,2,10") do echo a=%%a

echo **Options tokens ^ delims:

for /f "tokens=1-3 delims=," %%a in ("1,2,10") do echo a=%%a b=%%b c=%%c

pause

===============================================

@echo off

echo 本文件夹里面的文件有:

for /f "skip=5 tokens=3* delims= " %%a in ('dir') do (

if not "%%a"=="DIR" if not "%%b"=="字节" if not "%%b"=="可用字节" echo %%b

)

pause

===============================================

@echo off

echo 本文件夹里面的文件有:

dirc: ile.txt

for /f "skip=5 tokens=3* delims= " %%a in (c: ile.txt) do (

if not "%%a"=="DIR" if not "%%b"=="字节" if not "%%b"=="可用字节" echo %%b

)

del c: ile.txt

pause

===============================================

对于后面的两个例子,其中options里面的delims= 是可以删除的,因为只要添加了/F开关系统就将delims的值默认为空格。

符号字符串中的最后一个字符星号,

那么额外的变量将在最后一个符号解析之后

分配并接受行的保留文本。本例中也可以改为4,不过文件名中有空格的文件,只能显示空格以前部分

同时我们也看到了,for语句的do后面的command也是可以分行的,只需要保证command的左括号和do在同一行就可以了。

4、开关/D或/R

含开关/D或/R的for语句是与目录或文件有关的命令,一般情况下很少使用。含开关/R的命令有时候被用于通过遍历文件夹来查找某一个文件或文件夹,故而列举此例。

含开关/R的for语句举例(文件夹遍历):

===============================================

@echo off

setlocal enabledelayedexpansion

FOR /R d: %%i IN (.) DO (

set dd=%%i

set "dd=!dd:~0,-1!"

echo !dd!

)

pause

exit

===============================================

握了这套命令,那么你就离批处理达人不远了!

教你如何在win10下自动运行python程序脚本

写一个小的python程序,如test.py

由于python执行的比较快,窗口会一闪而过,所以加入while循环保持窗口。

在和test.py文件的同文件夹下 ,新建一个.bat文件,例如run.bat 这是由于python文件不是可执行文件,所以需要借助bat文件进行操作。

第二行是执行这个test.py文件

右键单击此电脑或我的电脑,点击 管理 -系统工具 -任务计划程序 -任务计划程序库

之后点击右侧创建基本任务

上述操作的图就不放了,参考链接:

进入创建基本任务后,名称随意取,描述可选填,点击下一步

触发器,什么时候触发脚本,这里先选择一次,点击系一部之后选择一次的时间,这里往后写几分钟,方便一会查看结果 点击下一步

操作这里默认启动程序就可以,点击下一步

选择要执行的脚本文件,选择浏览,选中run.bat文件点击打开 ,点击下一步

点击完成

在任务计划程序库中找到刚才建立的 测试 任务,在右下方有属性选项点击,更改红色圈出来的地方。 也可以在触发器中更改触发时间,或者新建触发条件

等待触发时间到,就会运行改脚本,按住Ctrl+C停止运行,测试成功

原文链接:

在windows系统中做个自动删除过期文件的脚本但是不执行

此文章链接无法写入,《知道》会删除

有些厂家的软件做得不够好,产生的文件比如日志文件等虽然每天占用的容量小,时间长了却是一堆很大的垃圾,厂家又没有定期删除的设置,于是我上网找了一个范例脚本,自己改了改,记录备用。

forfiles /p "D:bigantlogs" /s /m *.* /d -3 /c "cmd /c del @path" ,将其保存为.bat文件即可。

在windows server 2003系统中有一个forfiles命令能够查找满足指定条件的文件,下面是这个命令的用法。

forfiles /p 目标目录名 /d 天数 /c 执行的命令

看看列出的三个参数都有什么用处:

/p 指定了要在哪个目录里查找文件,默认是当前工作目录。

/d 指定一个日期或天数,用于比较文件的最后修改日期是否符合条件。

/c 对每个找到的文件执行的命令。

删除文件的代码举例:

forfiles /p 包含要删除文件的完整路径(如:F:Logfiles) /m *.log -d -7 /c "cmd /c del /f @path"

解释一下相关参数及命令

/p : 指定开始搜索文件的位置,如果不指定则默认为当前目录。

/m : 文件查找所使用的通配符如代码中的"*.log"则为所有日志文件,当然也可以指定诸如"manmee_*.log"这样以manmee开头的所有日志文件。如果不指定此参数则默认为"*.*"。

/d [{+|-}][{|}] : 指定想选择文件的最后修改时间,上文中用了 "/d -7" 表示所有以当天为基础,7天以前的文件。当然这里还可以指定具体时间,例如:"/d -08/18/2009"这样所有早于2009年8月18日的文件。注意指定的时间必须是"MM/DD/YYYY"的格式。

/c 对所有文件以此执行指定的命令,命令体须在双引号(")内。

【ddwindows脚本】的内容来源于互联网,若引用不当,请发邮件联系删除

相关文章 8

1

美国挂机服务器(美国挂机宝) 3分钟前

以往,大家大多使用个人电脑来做作为挂机使用,这不仅仅会加速电脑的老化,也需要支付高昂的电费、宽带费。那么怎么解决?使用云服...

2

韩国vps有哪些(免费的vps有哪些) 3分钟前

目录:1、本人想代理香港和韩国vps2、哪里有最稳定韩国服务器租用?需要能放游戏站,可以抗攻击的,不限流量的3、韩国vps多少钱一年4、...

3

大理网页制作(大理网站设计公司) 4分钟前

目录:1、我预定于1月18号从昆明坐火车到大理,请问要不要提前买票,票价多少,几个小时到达?2、云南旅游景点大全3、大理白族自治州...

4

有没有三网直连的便宜韩国vps(怎么能让中国网络直连韩国) 6分钟前

目录:1、可以国外的vps2、谁来科普一下,香港,俄罗斯,新加坡,日本,韩国的vps3、便宜又好用的美国VPS主机推荐4、国外VPS云服务器选择...

5

韩国vps服务器文档介绍内容(VPS文件) 7分钟前

目录:1、什么是VPS,请问具体怎么使用?2、日本vps和韩国vps哪个延迟3、什么叫VPS服务器4、vps韩国uplus线路好吗5、vps服务器是什么什么是...

6

加拿大高防vps(加拿大高地) 8分钟前

目录: 【加拿大高防vps】的内容来源于互联网,若引用不当,请发邮件联系删除...

7

最好用的云电脑(最好用的云电脑推荐) 11分钟前

目录:1、云电脑那个好用?2、云电脑谁用过好用吗3、什么云电脑好用?4、目前有什么云电脑推荐?云电脑那个好用? 之前的云电脑大家都...

8

国内裸金属服务器(裸金属 服务器) 14分钟前

目录: 【国内裸金属服务器】的内容来源于互联网,若引用不当,请发邮件联系删除...