❶ 脚本乱码怎么解决方法
bat脚本在批处理的时候被经常用到,但是有时候不正确的使用,会导致在bat脚本中的中文,运行起来的时候显示为乱码,这个让人很不爽,下面分享下自己解决这个问题的方法。
工具/原料
Bat脚本
电脑
习惯性的,我会在notepad工具中去编辑我的一些文本文件,如下如:
9
上图,可以看到中文都可以显示正常了。
写bat的时候 ,大家最好用文本去编辑,然后保存的时候,记得设置好他的编码方式
方法/步骤
注意事项
❷ shell脚本里,如何删除变量的最后一个字符
STR=123456abc
FINAL=`echo ${STR: -1}`
或者
FINAL=${STR: -1}
都可以让FINAL获得c这个最后一个字符
❸ asp怎么处理字符展示脚本信息
<%
class stringoperations
****************************************************************************
@功能说明: 把字符串换为镇茄蚂char型数组
@参数说明: - str [string]: 需要转换的字符串
@返回值: - [array] char型数组
****************************************************************************
public function tochararray(byval str)
redim chararray(len(str))
for i = 1 to len(str)
chararray(i-1) = mid(str,i,1)
next
tochararray = chararray
end function
****************************************************************************
@功能说明: 把一个数组转换成一个字符串
@参数说明: - arr [array]: 需要转换的数据
@返回值: - [string] 字符串
****************************************************************************
public function arraytostring(byval arr)
for i = 0 to ubound(arr)
strobj = strobj & arr(i)
next
arraytostring = strobj
end function
****************************************************************************
@功纳誉能说明: 检查源字符串str是否以chars开头
@参数说明: - str [string]: 源字御埋符串
@参数说明: - chars [string]: 比较的字符/字符串
@返回值: - [bool]
****************************************************************************
public function startswith(byval str, chars)
if left(str,len(chars)) = chars then
startswith = true
else
startswith = false
end if
end function
****************************************************************************
@功能说明: 检查源字符串str是否以chars结尾
@参数说明: - str [string]: 源字符串
@参数说明: - chars [string]: 比较的字符/字符串
@返回值: - [bool]
****************************************************************************
public function endswith(byval str, chars)
if right(str,len(chars)) = chars then
endswith = true
else
endswith = false
end if
end function
****************************************************************************
@功能说明: 复制n个字符串str
@参数说明: - str [string]: 源字符串
@参数说明: - n [int]: 复制次数
@返回值: - [string] 复制后的字符串
****************************************************************************
public function clone(byval str, n)
for i = 1 to n
value = value & str
next
clone = value
end function
****************************************************************************
@功能说明: 删除源字符串str的前n个字符
@参数说明: - str [string]: 源字符串
@参数说明: - n [int]: 删除的字符个数
@返回值: - [string] 删除后的字符串
****************************************************************************
public function trimstart(byval str, n)
value = mid(str, n+1)
trimstart = value
end function
****************************************************************************
@功能说明: 删除源字符串str的最后n个字符串
@参数说明: - str [string]: 源字符串
@参数说明: - n [int]: 删除的字符个数
@返回值: - [string] 删除后的字符串
****************************************************************************
public function trimend(byval str, n)
value = left(str, len(str)-n)
trimend = value
end function
****************************************************************************
@功能说明: 检查字符character是否是英文字符 a-z or a-z
@参数说明: - character [char]: 检查的字符
@返回值: - [bool] 如果是英文字符,返回true,反之为false
****************************************************************************
public function isalphabetic(byval character)
asciivalue = cint(asc(character))
if (65 <= asciivalue and asciivalue <= 90) or (97 <= asciivalue and asciivalue <= 122) then
isalphabetic = true
else
isalphabetic = false
end if
end function
****************************************************************************
@功能说明: 对str字符串进行大小写转换
@参数说明: - str [string]: 源字符串
@返回值: - [string] 转换后的字符串
****************************************************************************
public function swapcase(str)
for i = 1 to len(str)
current = mid(str, i, 1)
if isalphabetic(current) then
high = asc(ucase(current))
low = asc(lcase(current))
sum = high + low
return = return & chr(sum-asc(current))
else
return = return & current
end if
next
swapcase = return
end function
****************************************************************************
@功能说明: 将源字符串str中每个单词的第一个字母转换成大写
@参数说明: - str [string]: 源字符串
@返回值: - [string] 转换后的字符串
****************************************************************************
public function capitalize(str)
words = split(str," ")
for i = 0 to ubound(words)
if not i = 0 then
tmp = " "
end if
tmp = tmp & ucase(left(words(i), 1)) & right(words(i), len(words(i))-1)
words(i) = tmp
next
capitalize = arraytostring(words)
end function
****************************************************************************
@功能说明: 将源字符str后中的过滤为
@参数说明: - str [string]: 源字符串
@返回值: - [string] 转换后的字符串
****************************************************************************
public function checkstr(str)
if trim(str)="" or isnull(str) then
checkstr=""
else
checkstr=replace(trim(str),"","")
end if
end function
****************************************************************************
@功能说明: 将字符串中的str中的html代码进行过滤
@参数说明: - str [string]: 源字符串
@返回值: - [string] 转换后的字符串
****************************************************************************
public function htmlencode(str)
if trim(str)="" or isnull(str) then
htmlencode=""
else
str=replace(str,">",">")
str=replace(str,"<","<")
str=replace(str,chr(32)," ")
str=replace(str,chr(9)," ")
str=replace(str,chr(34),""")
str=replace(str,chr(39),"'")
str=replace(str,chr(13),"")
str=replace(str,chr(10) & chr(10), "</p><p>")
str=replace(str,chr(10),"<br> ")
htmlencode=str
end if
end function
****************************************************************************
@功能说明: 计算源字符串str的长度(一个中文字符为2个字节长)
@参数说明: - str [string]: 源字符串
@返回值: - [int] 源字符串的长度
****************************************************************************
public function strlen(str)
if trim(str)="" or isnull(str) then
strlen=0
else
dim p_len,x
p_len=0
strlen=0
p_len=len(trim(str))
for x=1 to p_len
if asc(mid(str,x,1))<0 then
strlen=int(strlen) + 2
else
strlen=int(strlen) + 1
end if
next
end if
end function
****************************************************************************
@功能说明: 截取源字符串str的前lennum个字符(一个中文字符为2个字节长)
@参数说明: - str [string]: 源字符串
@参数说明: - lennum [int]: 截取的长度
@返回值: - [string]: 转换后的字符串
****************************************************************************
public function cutstr(str,lennum)
dim p_num
dim i,x
if strlen(str)<=lennum then
cutstr=str
else
p_num=0
x=0
do while not p_num > lennum-2
x=x+1
if asc(mid(str,x,1))<0 then
p_num=int(p_num) + 2
else
p_num=int(p_num) + 1
end if
cutstr=left(trim(str),x)&"..."
loop
end if
end function
end class
%>
❹ 电脑开机时出现“脚本行字符错误码代码源”,怎么处理
1、清除一下IE浏览器的缓存,点IE上的工具——然后再选择最下面的Internet选项,再点Internet删除文件(记得勾上删除所有脱机内容),确定后再重新打开IE浏览器试试,同时请确认您使用的是IE6.0及以上版本。
2、您的网页上清缓存,在网页上选择工具->Interner选项->删除Cookies和删除文件,然后再确定。
3、请您点击IE浏览器中的“工具”,选择“internet选项”,进入“安全”页面,点击“自定义级别”,将您的安全设置设为“低”。
4、清空一下IE浏览器的cookies文件,在IE浏览器中设置“禁止自动脚本更新”,并不要选择“禁止运行ActiveX控件”,然后再尝试操作。
❺ jenkins插件怎么处理执行脚本返回的字符串
ls *.* | grep -i "flag.dat" 列出当前目录中文件名中含有点的文件并找含有flag.dat的文件,-i表示不区分大小写!当有一个文件的文件名为fmstarflag.dat时,执行$JOBDIR/bin/fmstarupd.sh这个脚本,并且删除
$LOADDIR/fmstarflag.dat,大体就这么个意思,要是还不懂的话,建议先学学shell的语法吧!
❻ shell脚本如何删除指定字符串,文档如下:
用正则匹配就可以了。
shell脚本regex正则表达式 和 字符串替换
任意字符
^行首匹配
$行尾匹配
^$表示空行,不含字符的行
^
$匹配只有单个空格的行
[0-9]
[a-zA-Z]
^[A-
Z]搜索以大写字母开头的行
[^A-Z]匹配大写字母意外的任意字符
*表示匹配0个或若干个字符,如:a*,表示匹配0个或若干个a;
aa*表示匹配至少1个a
.*来表示0或若干个任意字符
e.e*表示匹配第一个e和最后一个e之间的任意字符
[-0-9]匹配一
个连字符或数字
[]a-z]匹配一个]或者字母
\{min,max\}匹配任意数目的字符串
[a-z]\{10\}只匹配10个
a-z字符的字符串
s/.\{5\}$// 删除每行的最后5个字符
\(...\),n是1到9的数字,表示存储用的寄存器,用\n来引
用存在寄存器中的内容
^\(.\)\1匹配行首的第一个字符,并将该字符存到1号寄存器中,然后匹配1号寄存器中的内容,这由\1的描述。该正则
表达式的最终效果是,如果一行的头两个字符相同,就匹配他们。
^\(.\).*\1$匹配一行中的头一个字符(^.)跟最后一个字符(\1$)相
同的行。.*匹配中间的所有内容
^\(...\)\(...\)行中头三个字符存在1号寄存器,接着的三个字符存在2号寄存器.
s/\(.*\)
\(.*\)/\2 \1/g 交换两个字段
.任何字符
^行首
$行尾
*前导的正则表达式重复0或若干次
[字
符表]字符中的任一字符
a..表示a后的2个字符
^wood表示行首的wood
x$表示行为的x
^INSERT$只包含
字符串INSERT的行
^$不包含任何字符的行
x*表示0或若干个连续的x
xx*表示1或多个连续的x
.*表示0活若干
个字符
w.*s表示以w开始,s结尾的任何字符串
[tT]小写或大写的t
[^字符表]表示任一不在字符表中的字符 [^0-9]
[^a-zA-Z]
\{min,max\}表示前导的正则表达式重复只烧min次,至多max次[0-9]\{3,9\}表示3到
9个数字
\(...\)表示将小括号中匹配的字符串存储到下一个寄存器中(1-9),
^\(.\)表示行中第1个字符存到1号寄存器
^\
(.\)\1表示行首恋歌字符,且他们相同
cut -c5 file把file文件中没行的第5个字符析取出来;
用逗号分割的数
值列表,如-c1,13,50把第1,13,50个字符析取出来
cut -c20-50把第20到50之间的字符析取出来
如
who | cut
-c1-8
who | cut -c1-8,18- 析取行中的第1到8个字符(用户名)和第18到行尾的字符(登录时间)
cut -ddchar
-ffields file其中,dchar是数据中分割各字段的分割符,fields表示要从文件file中析取出来的字段.
字
段编号从1开始,而且格式跟以前将的用来指定字符位置的数字一样(如-f1、2、8、-f1-3、-f4-)。
cut -d: -f1
/etc/passwd
如果已知字段之间使用制表符分隔的,就可以给cut命令用-f选项而不用-c选项,好多了!还记得吧,这里用不着用-d选
项来指定分割符,因为
cut把制表符默认为分割符。
paste和cut正好相反,它不是把行分离开,而是把多行合并在一起。
paste
names numbrs文件names中的每一行都和numbers中的对应行显示在一起,中间用制表符分割。
如果不想用制表符作默认分割,
可以使用-dchars指定分割符
paste -d'+' names addresses numbers
-s选项告诉paste把同
一文件中的行粘贴在一起,而不是从其他文件。如果只指定一个文件名,其效果是把文件中的所有行合并成一行,原来隔行之间用制表符或者有-d选项指定的分割
符分割。
sed是用来编辑数据的程序,意指流编辑器(stream editor)。与ed不同,sed不能用于交互,
-n选
项,然后使用p命令显式指定
sed -n '1,2p' file只显示前2行
sed -n '/Unix/p'
file只打印包含Unix的行
删除行
d删除整行文件
sed '1,2d' file删除1和2行
记住sed默认把输入
的所有行写入标准输出,所以生于行的文字,也就是从第3行到结尾,都被写入标准输出。
sed '5d'删除第5行
sed
'/[Tt]est/d'删除包含test或Test的行
sed -n '20,25p' test只显示文件test的第20行到第25行
sed
'1,10s/unix/UNIX/g' intro报intro前10行中的unix改为UNIX
sed
'/jan/s/-1/-5/'将所有包含jan的行中第1个-1改为-5
sed 's/...//'
data删除data文件每一行的前3个字符
sed 's/...$//' data删除data文件每一行的最后3个字符
sed -n 'I'
text显示文件text的所有行,把所有不可打印字符显示为\nn,制表符显示为\t
过滤器tr用来转换来自标准输入的字
符,tr命令的一般格式为
tr from-chars to-chars
tr e x <
intro把所有字母e转换成x
tr命令的输入必须重定向到文件intro,因为tr总是从标准输入获得输入;转换的结果写入标准输出,而原始文
件保持不变。
cut -d: -f1,6 /etc/passwd | tr : ' '
通过在管道线的最后加上适当的tr命令,就可以把冒号转换成制表符,这样产生的输出更容易看
单引号中括的是制表符(尽管你看不到)。必须将它括在
引号中,以便穿过shell,使tr有机会看到它。
使用\nnn来给tr提供8进制表示的字符
一些ascii字符的八进制值
响 铃
7
退格 10
制表符 11
新行 12
换行 12
换页 14
回 车
15
转义 33
date | tr ' ' '\12'此例中,tr接受date命令的输出,并把所有的空格转换成换行
tr
'[a-z]' '[A-Z]'
<intro将所有小写转换为大写
-s选项,tr命令中的-s选项用来压缩to-chars中重复的字符,换句话说,如果转换完成后,有
to-chars中的某个字符连续出现多次,则这些连续相同的字符被替换为一个字符。
如下面的命令将冒号转换为制表符,并将多个连续制表符替换为
单个制表符:
tr -s ':' '\11\'
tr -s ' ' ' '
<lotspaces通过-s将多个空格全部压缩为单个空格
-d选项用来删除掉输入流中的字符,其一般格式为
tr -d
from-chars任何列在from-chars中的字符都会被从标准输入中删除。下例用tr来删除文件intro中的所有空格:
tr -d ' '
<intro
当然sed 's/ //g' intro也可以得到同样的效果
tr 'X' 'x' 把大X专成小x
tr '()'
'{}' 把所有左小括号转换成左大括号,右小括号专成右大括号
tr '[a-z]' '[A-Z]' 把小写转大写
tr '[A-Z]'
'[N-ZA-M]' 把A-M字母分别专成N-Z把N-Z转成A-M
tr ' ' ''把所有制表符转换成空格
tr -s ' '
''把多个空格转换成单个空格
tr -d '\14' 删除所有换页字符(八进制14)
tr -d '[0-9]'删除所有数字
grep
'[A-Z]' list list中包含一个大写字母的行
grep '[0-9]' data中包含数字的行
grep '[A-Z]...[0-9]'
list list中包含以大写字母开始、数字结尾的5个字符组合的行
grep '\.pic$' filelist
filelist中以.pic结尾的行
uniq in_file
out_file该格式中,uniq把in_file复制到out_file,处理过程中,去掉其中的重复行。如果不指定第2个参数out_file,结
果就写入标准输出;如果in_file没有指定,那么uniq就成了一个过滤器,从标准输入读取输入。
>或<
重定向,覆盖原有的内容
>>或<< 重定向,想文件末尾追加内容
tee 显示在终端上的内容存储到文件 ls |
tee >glx
-d 目录
-e 存在
-f 普通文件
-r 进程可读文件
-s 长度不为0
-w
进程可写文件
-x 可执行
-L 链接文件
$# 传给程序的参数个数,或者执行set命令设置的参数个数
$*
对位置参数等的集中引用
$@ 跟$*相似,区别在于当加入双引号后("$@"),集中引用位置参数"$1","$2"...等
$0
正执行的程序名
$$ 正执行程序的进程id
$! 最后一个发生后台运行的程序的进程id
$? 最后一个在前台执行的程序的退出状态
$-
当前有效选项标志
`command`符号之间的内容为需要执行的命令
make -C /lib/moles/`uname -r`/build
M=`pwd`
使用echo可以显示字符串,但是不能格式化字符串,可以使用printf实现
printf "format" arg1 arg2
...
ln -s from to 把from链接到to上,所以to是from的符号链接
tree -d只显示目录
tree -L
2显示2级目录
字符串比较
s1 = s2 s1等于s2
s1 != s2 s1不等于s2
s1
s1不为空
-n s1 s1不为空
-z s1 s1为空
整数比较操作
-eq 等于
-ge
大于或等于
-gt 大于
-le 小于或等于
-lt 小于
-ne 不等于
[ "$x1" = 5 ]字符串比较
[
"$x1" -eq 5 ]整数比较
-a 逻辑与操作
-o 逻辑或操作
command1 &&
command2
则先执行command1,如果返回的退出状态
为0,则执行command2;如果command1返回的退出状态非0,则跳过command2
command1 ||
command2
和上边的&&差不多,只是,仅仅当command1返回非0时,才执行command2
#!/bin/sh
append2=0
include_lib=1
if
[ -f cscope_i ];then
rm cscope_i
fi
for cscope_file in $*; do
if [ -f "$cscope_file" ] || [ -d "$cscope_file" ];then
# if [
$cscope_file = '-a' ];then
# append2=1
# continue
#
fi
#
# if [ $cscope_file = '-n' ];then
#
include_lib=0<F11>
# continue
# fi
if [ "$append2" = "1"
];then
find $cscope_file -maxdepth 1 -name '*.[cChH]' -o -name
'*.[cC][pP][pP]'>>cscope_i
else
find $cscope_file -name
'*.[cChH]' -o -name '*.[cC][pP][pP]'>>cscope_i
fi
else
if [
$cscope_file = '-a' ];then
append2=1
elif [ $cscope_file = '-n'
];then
include_lib=0
else
echo "Error: cannot read file
$cscope_file"
fi
fi
done
if [ -f cscope_i ];then
if [
"$include_lib" = "1" ];then
cscope -bi cscope_i
else
cscope -bki cscope_i
fi
rm cscope_i
fi
#linux(ubuntu)
❼ 批处理或者vbs脚本实现文件中字符串查找替换
写个批处理脚本,有局限性不能处理UTF8文本, 另外对替换串(CCC AAA)有某些特殊符限制,先 test 再说吧
@echooff
set"f1=test1.txt"
set"f2=test2.txt"
set"cs=CCC=AAA"
cd/d"%~dp0"
echo;正在查找...
for/f"tokens=1*delims=:"%%i知仿in(
'type"%f2%"^|findstr/ng:"%f1%"')do(
echo%%j
set"h=%%j"
call:yky#%%i)
echo;&goto:next
:yky
set"h=!h:%cs%!"
endlocal&set"%1=%h%"&goto:eof
:next
echo替换并写入文件...
(for指皮/f"tokens=1*delims=:"%%iin(
'type"%f2%"^|findstr/n.*')do(
set"h=%%j"
ifdefined#%%iset"h=!#%%i!"
>conecho;!h!
echo;!h!
唯猛差endlocal
))>"new.txt"
::move"new.txt""%f2%"
echo;&pause
❽ Unity3D脚本中文字符乱码怎么办
setfso=createobject("scripting.filesystemobject")settxt1=fso.opentextfile("1.txt",1)cod1=txt1.readalltxt1.closesettxt2=fso.opentextfile("2.txt",1)cod2=txt2.readalltxt2.closeifinstr(cod2,cod1)>敏团0thenmsgbox"找到了字符哗拿悄:"乱渣&cod1endif上源码测试可用。同目录下新建两个文件“1.txt”、“2.txt”。“1.txt”写进搜索关键词“中国人”,“2.txt”写入内容“我是中国人,你好。”。字符串比较不分什么文,只要你双引号里面的东西完全一样就相等。有一点点不同都不会相等。有任何问题追问吧。
❾ shell脚本里,如何删除变量的最后一个字符
STR=123456abc
FINAL=`echo
${STR:
-1}`
或者
FINAL=${STR:
-1}
都可以让FINAL获得c这个最后一返搏含个字符
Linux
的字符串截取很有用。有八种方法。
假设有变量
var=http://www.aaa.com/123.htm.
1.
#
号截取,删除左边字符,保留右边字符。代码如下:
echo
${var#*//}
其中
var
是变量名,#
号是运算符,*//
表示从左漏笑边开始删除第一个
//
号及左边的所有字符
即删除
http://
结果是
:www.aaa.com/123.htm
2.
##
号截取,删除左边字符,保留右边字符。代码如下:
echo
${var##*/}
##*/
表示从左边开始删除最后(最右边)一个
/
号及左边的所有字符
即删除
http://www.aaa.com/
结果是
123.htm
3.
%号截取,删除右边字符,保留左边字符代码如下:
echo
${var%/*}
%/*
表示从右边开始,删除第一个
/
号及右边的字符
结果是:http://www.aaa.com
4.
%%
号截取,删除右边字符,保留左边字符代码如下:
echo
${var%%/*}
%%/*
表示从右边开始,删除最后(最左边)一个
/
号及右边的字符
结果是:http:
5.
从左边第几个字符银烂开始,及字符的个数代码如下:
echo
${var:0:5}
其中的
0
表示左边第一个字符开始,5
表示字符的总个数。
结果是:http:
6.
从左边第几个字符开始,一直到结束。代码如下:
echo
${var:7}
其中的
7
表示左边第8个字符开始,一直到结束。
结果是
:www.aaa.com/123.htm
7.
从右边第几个字符开始,及字符的个数。代码如下:
echo
${var:0-7:3}
其中的
0-7
表示右边算起第七个字符开始,3
表示字符的个数。
结果是:123
8.
从右边第几个字符开始,一直到结束。
代码如下:
echo
${var:0-7}
表示从右边第七个字符开始,一直到结束。
结果是:123.htm
❿ shell脚本中怎样对特殊字符进行处理 一串密码在加密前对密码中的!@#$%等特殊字符进行处理(加上‘’)。
用sed正则匹配全局替换:
echo'Aa123!@#$'|sed"s/[^0-9a-zA-Z]/'&'/g"
这样就把不是字母或数字的其他字符都加上单引号啦
当然,如果原输入中不存在特殊字符,就还是原样输出,不会做任何改变。