执行脚本前
❶ 如何运行linux shell程序
如何运行shell程序,如何在shell程序以及后续脚本中使用同一个变量,这些在工作中经常用到, 我找到如下的文章,再加深复习一下。
1 source命令用法:
source FileName
作用:在当前bash环境下读取并执行FileName中的命令。该filename文件可以无"执行权限"
注:该命令通常用命令“.”来替代。
如:source .bash_profile
. .bash_profile两者等效。
source(或点)命令通常用于重新执行刚修改的初始化文档。
source命令(从 C Shell 而来)是bash shell的内置命令。
点命令,就是个点符号,(从Bourne Shell而来)。
source的程序主体是bash,脚本中的$0变量的值是bash,而且由于作用于当前bash环境,脚本中set的变量将直接起效
2 sh, bash的命令用法:
sh/bash FileName
作用:打开一个子shell来读取并执行FileName中命令。该filename文件可以无"执行权限"
注:运行一个shell脚本时会启动另一个命令解释器.
每个shell脚本有效地运行在父shell(parent shell)的一个子进程里.
这个父shell是指在一个控制终端或在一个xterm窗口中给你命令指示符的进程.
shell脚本也可以启动他自已的子进程.
这些子shell(即子进程)使脚本并行地,有效率地地同时运行脚本内的多个子任务.
在ubuntu中sh只是bash的一个链接。
由于是在子shell中执行,脚本设置的变量不会影响当前shell。
3 ./的命令用法:
./FileName
作用:打开一个子shell来读取并执行FileName中命令。该filename文件需要"执行权限"
注:运行一个shell脚本时会启动另一个命令解释器.
每个shell脚本有效地运行在父shell(parent shell)的一个子进程里.
这个父shell是指在一个控制终端或在一个xterm窗口中给你命令指示符的进程.
shell脚本也可以启动他自已的子进程.
这些子shell(即子进程)使脚本并行地,有效率地地同时运行脚本内的多个子任务.
由于是在子shell中执行,脚本设置的变量不会影响当前shell。
4 export:
一个变量创建时,它不会自动地为在它之后创建的shell进程所知。而命令export可以向后面的shell传递变量的值。当一个shell脚本调用并执行时,它不会自动得到原为脚本(调用者)里定义的变量的访问权,除非这些变量已经被显式地设置为可用。export命令可以用于传递一个或多个变量的值到任何后继脚本
5. 举例
比如您在一个脚本里export $KKK=111 ,假如您用./a.sh执行该脚本,执行完毕后,您运行 echo $KKK ,发现没有值,假如您用source来执行 ,然后再echo ,就会发现KKK=111。因为调用./a.sh来执行shell是在一个子shell里运行的,所以执行后,结构并没有反应到父shell里,但是 source不同他就是在本shell中执行的,所以能够看到结果.
小测试
1 建立test.sh
#!/bin/bash
export s=/home/jboss/
2 执行命令: source test.sh
echo $s
结果输出: /home/jboss/
3 新开个shell
执行命令: ./test.sh
echo $s
结果: 没有输出s值
结论:
1、执行脚本时是在一个子shell环境运行的,脚本执行完后该子shell自动退出。
2、一个shell中的系统环境变量才会被复制到子shell中(用export定义的变量);
3、一个shell中的系统环境变量只对该shell或者它的子shell有效,该shell结束时变量消失(并不能返回到父shell中)。3、不用 export定义的变量只对该shell有效,对子shell也是无效的。
直接执行一个脚本文件是在一个子shell中运行的,而source则是在当前shell环境中运行的。
source可以让脚本影响它们的父shell环境,这和export去影响子shell环境相反.
❷ 如何使用Transact-SQL脚本语言导入Excel表
一、执行导入脚本前需要做的几项工作
注意:如果以下几步不执行,导入数据时会提示出错,错误信息一般有如下3种(可能不限于此):
1、开启Ad HocDistributed Queries服务:
开启方式如下:
--开启AdHoc Distributed Queries:
sp_configure 'show advanced options',1;
RECONFIGURE;
sp_configure 'Ad Hoc Distributed Queries',1;
RECONFIGURE;
2、Microsoft.Jet.OLEDB.4.0引擎设置阻止了导入和导出:
设置方式如下(以SQL Server 2008为例):
SQL Server Management Studio à服务器对象à链接服务器à访问接口àMicrosoft.Jet.OLEDB.4.0à右键属性à访问接口选项:全都不选
3、SQL Server(MSSQLSERVER)和SQL Full-FilterDeamon Launcher 服务的登录身份设置错误:
设置方式如下:
打开SQLServer Configuration Management,将SQL Server(MSSQLSERVER)和SQL Full-text Filter Daemon Launcher(MSSQLSERVER)两个服务的登录身份改为LocalSystem。
4、确保要导入的数据格式正确
5、确保在导入数据时,Excel表或者其他数据库表没有被其他软件打开
6、确定你的Office版本,选择合适的SQL语句进行导入(具体语句后面会提到)
二、导入数据并新增表
1、Excel表为xls格式
SELECT * INTO NewXls FROMOPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel5.0;HDR=YES;DATABASE=G:\示例\XLS格式.xls',sheet1$)
2、Excel表为xlsx格式
SELECT * INTO NewXlsx FROM
OPENDATASOURCE('Microsoft.ACE.OLEDB.12.0','DataSource=G:\示例\XLSX格式.xlsx;Extended Properties=Excel 12.0')...[sheet1$]
三、导入完成后,关闭Ad HocDistributed Queries
导入数据完成后,记得要关闭Ad Hoc Distributed Queries,因为这是一个安全隐患。关闭方法如下:
--使用完成后,关闭AdHoc Distributed Queries:
sp_configure 'Ad Hoc Distributed Queries',0;
RECONFIGURE;
sp_configure 'show advanced options',0;
RECONFIGURE;
❸ expect脚本在Linux下是如何使用的
如果你是expect脚本语言的新手,可以首先从我们的expect的“hello world”样例(英文)开始。
1,使用“-c”选项,从命令行执行expect脚本
expect可以让你使用“-c”选项,直接在命令行中执行它,如下所示:
$ expect -c 'expect "\n" {send "pressed enter\n"}
pressed enter
$
如果你执行了上面的脚本,它会等待输入换行符(\n)。按“enter”键以后,它会打印出“pressed enter”这个消息,然后退出。
2,使用“-i”选项交互地执行expect脚本
使用“-i”选项,可以通过来自于标准输入的读命令来交互地执行expect脚本。如下所示:
$ expect -i arg1 arg2 arg3
expect1.1>set argv
arg1 arg2 arg3
expect1.2>
正常情况下,当你执行上面的expect命令的时候(没有“-i”选项),它会把arg1当成脚本的文件名,所以“-i”选项可以让脚本把多个参数当成一个连续的列表。
当你执行带有“-c”选项的expect脚本的时候,这个选项是十分有用的。因为默认情况下,expect是交互地执行的。
3,当执行expect脚本的时候,输出调试信息
当你用“-d”选项执行代码的时候,你可以输出诊断的信息。如下所示:
$ cat sample.exp
# !/usr/bin/expect -f
expect "\n";
send "pressed enter";
$ expect -d sample.exp
expect version 5.43.0
argv[0] = expect argv[1] = -d argv[2] = sample.exp
set argc 0
set argv0 "sample.exp"
set argv ""
executing commands from command file sample.exp
expect: does "" (spawn_id exp0) match glob pattern "\n"? no
expect: does "\n" (spawn_id exp0) match glob pattern "\n"? yes
expect: set expect_out(0,string) "\n"
expect: set expect_out(spawn_id) "exp0"
expect: set expect_out(buffer) "\n"
send: sending "pressed enter" to { exp0 pressed enter}
4,使用“-D”选项启动expect调试器
“-D”选项用于启动调试器,它只接受一个布尔值的参数。这个参数表示提示器必须马上启动,还是只是初始化调试器,以后再使用它。
$ expect -D 1 script
“-D”选项左边的选项会在调试器启动以前被处理。然后,在调试器启动以后,剩下的命令才会被执行。
$ expect -c 'set timeout 10' -D 1 -c 'set a 1'
1: set a 1
dbg1.0>
5,逐行地执行expect脚本
通常,expect会在执行脚本之前,把整个脚本都读入到内存中。“-b”选项可以让expect一次只读取脚本中的一行。当你没有写完整个脚本的时候,这是十分有用的,expect可以开始执行这个不完整的脚本,并且,它可以避免把脚本写入到临时文件中。
$ expect -b
6,让expect不解释命令行参数
你可以使用标识符让expect不解释命令行参数。
你可以像下面这样的读入命令行参数:
$ cat print_cmdline_args.exp
#!/usr/bin/expect
puts 'argv0 : [lindex $argv 0]';
puts 'argv1 : [lindex $argv 1]';
当执行上面的脚本的时候,会跳过命令行选项,它们会被当成参数(而不是expect选项),如下所示:
$ expect print_cmdline_args.exp -d -c
argv0 : -d
argv1 : -c
❹ 脚本精灵怎么使用
一、 使用前的检测
1. 进入软件,点击下方的“设置”,点击第一个选项“程序配置”
2. 看“性能设置”里面的“设备兼容模式”后面的复选框是否打勾,如果打勾则取消
3. 点击最后一项“脚本界面显示设置”,选择第二项“播放脚本前显示”
4. 返回脚本列表,随便点击一个脚本,点击“载入”,此时软件界面退出,出现悬浮条
5. 点击悬浮条第二个按钮,出现第二行,点击第二行倒数第二个按钮,看看是否花屏或者黑屏,正常情况下应该是手机界面的一个缩小版,即手机截图
6. 如果正常则表示你的手机可以使用脚本精灵恋舞刷分脚本。
二、 下载导入脚本
1. 下载恋舞刷分脚本(后缀名为.se的脚本文件)
2. 将脚本文件(.se文件)复制到手机内存卡根目录(或者其它你可以找到目录)
3. 进入脚本精灵脚本列表,点击右上方第二个按钮,在出现的悬浮窗(类似于文件管理器)里面找到你刚才复制到手机中的脚本,点击“导入”
4. 退出脚本精灵软件,重新进入,就可以在脚本列表找到刚才导入的脚本了
三、 界面配置及使用
1. 在脚本列表点击恋舞脚本,点击“载入”,此时软件界面退出,出现悬浮条
2. 进入恋舞OL,恋舞模式,点击游戏“开始”以后,点击脚本精灵悬浮条第三个按钮“播放”,弹出配置框
3. 点击“配置”,在这里可以看到配置参数(不同分辨率手机配置参数不同,初次测试默认即可),点击确定即开始执行脚本,此时便可看到效果。
半自动的前面的按键需要自己手动点,脚本帮你按P键
全自动的完全无需手动操作
4. 当一首歌播放完毕时,点击第四个按钮“停止”,回游戏大厅准备进入下一首歌曲
四、 脚本刷分说明
目前仅支持恋舞模式,不保证全P,脚本刷分的原理是通过取色获取屏幕上红色进度条的位置,然后做出判断,在合适的时间点击P键,由于手机性能的差异,不同的手机P的效果会有很大差异。
如果P的位置不准,大多偏向于精确位置的左侧或者右侧,可以在播放前调整参数优化P的位置,向左或者向右,每点击一次增加或减少1像素,一般情况下5像素会有明显效果。
五、 获取设备信息(IMEI)
~ 1 / 2 ~
进入脚本精灵,点击“设置”,点击第三项“系统信息”,在这里即可找到手机 IMEI号码
❺ C#代码在后台动态执行前台脚本的几种方法
在C#代码中经常需要动态的在前台页面执行javascript脚本,一般主要用到三种方法:Response.Write;RegisterStartupScript和RegisterClientScriptBlock,之前对三者的区别一直没仔细研究,今天是第一次写博客,就先说说他们吧……Response.Write方法,可以将内容直接输出到页面中,但会输出到页面最前端,此时如果输出的是javascript脚本的话,可能会导致样式表失效或浏览器发生错误等不可预知的问题。RegisterStartupScript和RegisterClientScriptBlock都是Page类中ClientScript属性的一个方法,是原型相同功能类似的两个方法,区别在于输出脚本在页面中的位置不同。先来看看微软对这两个方法的描述k在Page对象的元素开始标记之后立即发出客户端脚本,RegisterStartupScript则是在Page对象的元素的结束标记之前发出该脚本。所以如果你的脚本需要跟页面对象进行交互的话,推荐使用RegisterStartupScript。在页面源代码中显示的位置如下:RegisterClientScriptBlock一般返回的是客户端函数的封装,而RegisterStartupScript返回的函数在document装载完成后会执行。