2006年09月05日

要先引用System.Management;

ManagementClass mc = new ManagementClass("Win32_Processor");
   ManagementObjectCollection coll =  mc.GetInstances();
   foreach(ManagementObject mo in coll)
   {
    Response.Write(mo.Properties["ProcessorId"].Value.ToString());
   }

2006年08月22日

今天在天狮做接口,从最低的数据库接口开始,我本来想做一个由数组形势对一个表进行数据映射的接口的,结果遇见问题,数组下标无法是字符串,不知道怎么回事,结果就另找了一个办法用Hashtable(可能还有更多的方法来做,如table等)

下面给一个例子:

Hashtable ht = new Hashtable();
   ht.Add("name","123");
   ht.Add("id","123");
   ht.Add("age","123");
   
   foreach(string str in ht.Keys)
   {
    MessageBox.Show(str + "   " + ht[str]);
   }

 

这样就可以得到数据及字段名。

但是这个还不是我想要的最终结果,当务之急,就先拿这个整了,以后等想到更好的方法再说了。也希望大家

能帮我想想如何才能使数组能设字符串下标(arrValue["name"]=test;)

 

2006年08月18日

关于div的隐藏

                                      

 

div的visibility可以控制div的显示和隐藏,但是隐藏后页面显示空白

style="visibility: none;"

document.getElementById("typediv1").style.visibility="hidden";//隐藏

document.getElementById("typediv1").style.visibility="visible";//显示

 

通过设置display属性可以使div隐藏后释放占用的页面空间,如下

style="display: none;"

document.getElementById("typediv1").style.display="none";//隐藏

document.getElementById("typediv1").style.display="";//显示

 

还有,如果你要控制DIV的X、Y或是要做一个移动的DIV要加上style="position:absolute;"

XP下安装SQL2000企业版需要在XP下安装SQL2000企业版,可是发现提示只能安装客户端。怎么办呢?上网扒一下,找到了关于XP下安装SQL2000企业版的方法。如下:
SQL2000企业版本适用于WIN 2000系统,2003系统和XP一般装不了需要选用个人版。XP下安装装SQL2000企业版本方法以供参考。

方法如下:
一.在SQL服务器的安装盘中找到MSDE这个目录,并且点击setup.exe安装它,过程简单直接下一步就OK了。
  二. 重启系统WINDOWSXP,这下就可以看到SQL服务的图标出现了。
三. 再拿出SQL服务器版的安装光盘,直接安装客户端工具(这个不要多说吧?最简单的方法就是直接点击光盘根目录下的autorun.exe)根据提示安装,自检过程中知道系统不是SERVER版,会提示只安装客户端工具。
四. 打开企业管理器,试用SA用户连一下看看,是不是发现SA用户登陆失败?因为你还没有与信任SQL SERVER连接相关联。还好这个只要对系统注册表稍加修改就可以啦:在运行中输入regedit打开注册表编辑器,找到[HKEY_LOCAL_MACHINE\SOFTWARE\MICROSOFT\MSSQLSERVER\MSSQLSERVER],这个项里面有一个键值LoginMode,默认下,值是1,现在将值改为2,重启电脑。
五. 再打开企业管理,再连接试试,OK了!

2006年08月11日

今天要写个托盘程序玩结果没想法那么的简单。。

主要是用notifyIcon Control

然后在窗体初始化的时候进行判断,如果窗体是最小化了,那么就隐藏窗体显示notifyIcon

具体代码如下:

   public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            this.SizeChanged += new EventHandler(Form1_SizeChanged);
           
        }

        void Form1_SizeChanged(object sender, EventArgs e)
        {
            if (this.WindowState == FormWindowState.Minimized)
            {
                this.Hide();
                this.notifyIcon1.Visible = true;
            }
        }

以下代码省略!~~哈哈~~~

2006年07月15日

转换成字符串用strval()

 

MYSQL 数据库中日期型格式化

DATE_FORMAT(date,format)
根据format字符串格式化date值。下列修饰符可以被用在format字符串中: %M 月名字(January……December)
%W 星期名字(Sunday……Saturday)
%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)
%Y 年, 数字, 4 位
%y 年, 数字, 2 位
%a 缩写的星期名字(Sun……Sat)
%d 月份中的天数, 数字(00……31)
%e 月份中的天数, 数字(0……31)
%m 月, 数字(01……12)
%c 月, 数字(1……12)
%b 缩写的月份名字(Jan……Dec)
%j 一年中的天数(001……366)
%H 小时(00……23)
%k 小时(0……23)
%h 小时(01……12)
%I 小时(01……12)
%l 小时(1……12)
%i 分钟, 数字(00……59)
%r 时间,12 小时(hh:mm:ss [AP]M)
%T 时间,24 小时(hh:mm:ss)
%S 秒(00……59)
%s 秒(00……59)
%p AM或PM
%w 一个星期中的天数(0=Sunday ……6=Saturday )
%U 星期(0……52), 这里星期天是星期的第一天
%u 星期(0……52), 这里星期一是星期的第一天
%% 一个文字“%”。

2006年06月02日

<SCRIPT language="JavaScript1.2">
NS6 = (document.getElementById&&!document.all)
IE = (document.all)
NS = (navigator.appName=="Netscape" && navigator.appVersion.charAt(0)=="4")
tempBar=”;barBuilt=0;ssmItems=new Array();
moving=setTimeout(‘null’,1)
function moveOut() {
if ((NS6||NS)&&parseInt(ssm.left)<0 || IE && ssm.pixelLeft<0) {
clearTimeout(moving);moving = setTimeout(‘moveOut()’, slideSpeed);slideMenu(10)}
else {clearTimeout(moving);moving=setTimeout(‘null’,1)}};
function moveBack() {clearTimeout(moving);moving = setTimeout(‘moveBack1()’, waitTime)}
function moveBack1() {
if ((NS6||NS) && parseInt(ssm.left)>(-menuWidth) || IE && ssm.pixelLeft>(-menuWidth)) {
clearTimeout(moving);moving = setTimeout(‘moveBack1()’, slideSpeed);slideMenu(-10)}
else {clearTimeout(moving);moving=setTimeout(‘null’,1)}}
function slideMenu(num){
if (IE) {ssm.pixelLeft += num;}
if (NS||NS6) {ssm.left = parseInt(ssm.left)+num;}
if (NS) {bssm.clip.right+=num;bssm2.clip.right+=num;}}
function makeStatic() {
if (NS||NS6) {winY = window.pageYOffset;}
if (IE) {winY = document.body.scrollTop;}
if (NS6||IE||NS) {
if (winY!=lastY&&winY>Yoffset-staticYOffset) {
smooth = .2 * (winY – lastY – Yoffset + staticYOffset);}
else if (Yoffset-staticYOffset+lastY>Yoffset-staticYOffset) {
smooth = .2 * (winY – lastY – (Yoffset-(Yoffset-winY)));}
else {smooth=0}
if(smooth > 0) smooth = Math.ceil(smooth);
else smooth = Math.floor(smooth);
if (IE) bssm.pixelTop+=smooth;
if (NS6||NS) bssm.top=parseInt(bssm.top)+smooth
lastY = lastY+smooth;
setTimeout(‘makeStatic()’, 1)}}
function buildBar() {
if(barText.indexOf(‘<IMG’)>-1) {tempBar=barText}
else{for (b=0;b<barText.length;b++) {tempBar+=barText.charAt(b)+"<BR>"}}
document.write(‘<td align="center" rowspan="100" width="’+barWidth+’" bgcolor="’+barBGColor+’" valign="’+barVAlign+’"><p align="center"><font face="’+barFontFamily+’" Size="’+barFontSize+’" COLOR="’+barFontColor+’"><B>’+tempBar+’</B></font></p></TD>’)}
function initSlide() {
if (NS6){ssm=document.getElementById("thessm").style;bssm=document.getElementById("basessm").style;
bssm.clip="rect(0 "+document.getElementById("thessm").offsetWidth+" "+document.getElementById("thessm").offsetHeight+" 0)";ssm.visibility="visible";}
else if (IE) {ssm=document.all("thessm").style;bssm=document.all("basessm").style
bssm.clip="rect(0 "+thessm.offsetWidth+" "+thessm.offsetHeight+" 0)";bssm.visibility = "visible";}
else if (NS) {bssm=document.layers["basessm1"];
bssm2=bssm.document.layers["basessm2"];ssm=bssm2.document.layers["thessm"];
bssm2.clip.left=0;ssm.visibility = "show";}
if (menuIsStatic=="yes") makeStatic();}
function buildMenu() {
if (IE||NS6) {document.write(‘<DIV ID="basessm" style="visibility:hidden;Position : Absolute ;Left : ‘+Xoffset+’ ;Top : ‘+Yoffset+’ ;Z-Index : 20;width:’+(menuWidth+barWidth+10)+’"><DIV ID="thessm" style="Position : Absolute ;Left : ‘+(-menuWidth)+’ ;Top : 0 ;Z-Index : 20;" onmouseover="moveOut()" onmouseout="moveBack()">’)}
if (NS) {document.write(‘<LAYER name="basessm1" top="’+Yoffset+’" LEFT=’+Xoffset+’ visibility="show"><ILAYER name="basessm2"><LAYER visibility="hide" name="thessm" bgcolor="’+menuBGColor+’" left="’+(-menuWidth)+’" onmouseover="moveOut()" onmouseout="moveBack()">’)}
if (NS6){document.write(‘<table border="0" cellpadding="0" cellspacing="0" width="’+(menuWidth+barWidth+2)+’" bgcolor="’+menuBGColor+’"><TR><TD>’)}
document.write(‘<table border="0" cellpadding="0" cellspacing="1" width="’+(menuWidth+barWidth+2)+’" bgcolor="’+menuBGColor+’">’);
for(I=0;I<ssmItems.length;I++) {
if(!ssmItems[I][3]){ssmItems[I][3]=menuCols;ssmItems[I][5]=menuWidth-1}
else if(ssmItems[I][3]!=menuCols)ssmItems[I][5]=Math.round(menuWidth*(ssmItems[I][3]/menuCols)-1);
if(ssmItems[I-1]&&ssmItems[I-1][4]!="no"){document.write(‘<TR>’)}
if(!ssmItems[I][1]){
document.write(‘<td bgcolor="’+hdrBGColor+’" HEIGHT="’+hdrHeight+’" ALIGN="’+hdrAlign+’" VALIGN="’+hdrVAlign+’" WIDTH="’+ssmItems[I][5]+’" COLSPAN="’+ssmItems[I][3]+’">&nbsp;<font face="’+hdrFontFamily+’" Size="’+hdrFontSize+’" COLOR="’+hdrFontColor+’"><b>’+ssmItems[I][0]+’</b></font></td>’)}
else {if(!ssmItems[I][2])ssmItems[I][2]=linkTarget;
document.write(‘<TD BGCOLOR="’+linkBGColor+’" onmouseover="bgColor=\”+linkOverBGColor+’\'" onmouseout="bgColor=\”+linkBGColor+’\'" WIDTH="’+ssmItems[I][5]+’" COLSPAN="’+ssmItems[I][3]+’"><ILAYER><LAYER onmouseover="bgColor=\”+linkOverBGColor+’\'" onmouseout="bgColor=\”+linkBGColor+’\'" WIDTH="100%" ALIGN="’+linkAlign+’"><DIV ALIGN="’+linkAlign+’"><FONT face="’+linkFontFamily+’" Size="’+linkFontSize+’">&nbsp;<A HREF="’+ssmItems[I][1]+’" target="’+ssmItems[I][2]+’" CLASS="ssmItems">’+ssmItems[I][0]+’</DIV></LAYER></ILAYER></TD>’)}
if(ssmItems[I][4]!="no"&&barBuilt==0){buildBar();barBuilt=1}
if(ssmItems[I][4]!="no"){document.write(‘</TR>’)}}
document.write(‘</table>’)
if (NS6){document.write(‘</TD></TR></TABLE>’)}
if (IE||NS6) {document.write(‘</DIV></DIV>’)}
if (NS) {document.write(‘</LAYER></ILAYER></LAYER>’)}
theleft=-menuWidth;lastY=0;setTimeout(‘initSlide();’, 1)}
Yoffset=150;
Xoffset=0;
staticYOffset=30;
slideSpeed=20
waitTime=50;
menuBGColor="black";
menuIsStatic="yes";
menuWidth=150;
menuCols=2;
hdrFontFamily="verdana";
hdrFontSize="2";
hdrFontColor="white";
hdrBGColor="#170088";
hdrAlign="left";
hdrVAlign="center";
hdrHeight="15";
linkFontFamily="Verdana";
linkFontSize="2";
linkBGColor="white";
linkOverBGColor="#FFFF99";
linkTarget="_top";
linkAlign="Left";
barBGColor="#444444";
barFontFamily="Verdana";
barFontSize="2";
barFontColor="white";
barVAlign="center";
barWidth=0;
barText="快 捷 菜 单";
ssmItems[0]=["首  页", "#", ""]
ssmItems[1]=["给我留言", "#", ""]
ssmItems[2]=["版权声明", "#", ""]
ssmItems[3]=["合作条约", "#", ""]
ssmItems[4]=["联第我们", "#", ""]
buildMenu();</SCRIPT>

2006年05月29日

FSO,正如UFO般令人激动、令人神往,当然更多的亦是让人欢喜让人忧。君不见某空间服务商广告:100MB空间只要60RMB/年,支持数据库,支持什么什么……一问不支持FSO,立马泄气。那FSO究竟是什么东西,它的力量又是如何巨大,其操作的原理又是怎的怎的呢?这次来个彻底的理解。 
  首先,FSO是FileSystemObject的简称。当然也就是我们的俗称FSO组件了,该组件可以用来处理驱动器、文件夹以及文件。
  它可以检测并显示出系统驱动器的信息分配情况;还能够创建、改变、移动和删除文件夹,并能探测一些给定的文件夹是否存在,若存在,还能提取出该文件夹的信息,如名称、被创建或最后一次修改的日期,等等。FSO还使得对文件的处理变得很容易。
  一、fso.GetDrive
  正如其它组件的建立一样,FSO的引用也必须建立连接。

Set fso=Server.CreateObject("Scripting.FileSystemObject")
  注意CreateObject的内部再也不是MSWC了,而是Scripting。
  那下面就可以通过fso来处理驱动器了。比如fso.GetDriveName提取驱动器名,fso.GetDrive同样提取标准驱动器名。比如:
  1,fso.asp

<%Set fso=Server.CreateObject("Scripting.FileSystemObject")%>
<%=fso.GetDriveName("d:")%>
<br>
<%=fso.GetDrive("d:")%>
  你会发现GetDriveName("d:")就是“d:”,而GetDrive("d:")则为标准的“D:”,所以我们一般这样写fso.GetDrive(fso.GetDriveName(drvPath))来提取某个具体的驱动盘。
  二、drv.GetInfo
  上面已经把某个特定的驱动器提取了,那接着是不是提取该驱动盘的具体信息。
  2,drv.asp

<%Set fso=Server.CreateObject("Scripting.FileSystemObject")
Set drv=fso.GetDrive(fso.GetDriveName("d:"))%>
该盘的空间大小:<%=drv.TotalSize%><br>
该盘的剩余空间大小:<%=drv.FreeSpace%>
  以上只是提取的D盘驱动器的信息,来个通用的函数,继续分别测试自己的驱动吧。
  3,drvinfo.asp

<%
Function ShowDriveInfo(drvPath) 
Dim fso, drv, s 
Set fso = CreateObject("Scripting.FileSystemObject") 
Set drv = fso.GetDrive(fso.GetDriveName(drvPath)) 
s = "驱动盘" & drv & "的卷标是:" 
s = s & drv.VolumeName & "<br>" 
s = s & "总计空间:" & drv.TotalSize & "<br>" 
s = s & "剩余空间:" & drv.FreeSpace & "<br>" 
s = s & "文件类型:" & drv.DriveType & "<br>" 
s = s & "文件系统:" & drv.FileSystem 
Response.Write s
End Function%>
<%on error resume next
whatpath=request.form("path")
if whatpath<>"" then
ShowDriveInfo(whatpath)
end if%>
<form action="drvinfo.asp" method="post">
<input name="path">
<input type="submit">
</form>
  其中的drv.TotalSize和drv.FreeSpace返回的是字节数,我们可以用FormatNumber()函数处理下。比如FormatNumber(Drive.TotalSize/1024,0)得到一眼就知磁盘多少G的值。
  还有一个文件类型:drv.DriveType最多的时候是显示数值“2”,其实“2”就表示的“硬盘驱动器”,“1”表示“软盘驱动器”,“4”表示“光盘驱动器”……

  下面就用一个程序遍历显示自己机器上所有驱动器的信息。
  4,showall.asp

<%Function tran(Driver)
Select Case Driver
Case 0: tran="设备无法识别"
Case 1: tran="软盘驱动器"
Case 2: tran="硬盘驱动器"
Case 3: tran="网络硬盘驱动器"
Case 4: tran="光盘驱动器"
Case 5: tran="RAM虚拟磁盘"
End Select
End Functionset
 fso=Server.CreateObject("Scripting.FileSystemObject")%>
 <table border=1 width="100%">
 <tr>
 <td>盘符</td>
 <td>类型</td>
 <td>卷标</td>
 <td>总计大小</td>
 <td>可用空间</td>
 <td>文件系统</td>
 <td>序列号</td>
 <td>是否可用</td>
 <td>路径</td>
 </tr>
 <%on error resume next
 For each drv in fso.Drives 
 Response.Write "<tr>" 
 Response.Write "<td>" & drv.DriveLetter & "</td>" 
 Response.write "<td>" & tran(drv.DriveType) & "</td>" 
 Response.write "<td>" & drv.VolumeName & "</td>" 
 Response.write "<td>" & FormatNumber(drv.TotalSize / 1024, 0)& "</td>" 
 Response.write "<td>" & FormatNumber(drv.Availablespace / 1024, 0) & "</td>" 
 Response.write "<td>" & drv.FileSystem & "</td>" 
 Response.write "<td>" & drv.SerialNumber & "</td>" 
 Response.write "<td>" & drv.IsReady & "</td>" 
 Response.write "<td>" & drv.Path & "</td>" 
 Response.Write "</tr>"Nextset fs=nothing%>
 </table>
  演示
  恩,是不是很神气?那你可以对自己的机器调试,然后上传到自己的空间去调试,你会发现服务商会你进行了些设置:)
  当然更神的还在后面面,比如对文件夹,对文件的操作(包括添加、修改和删除)。
  ps:你对驱动器是不能轻易添加删除的:)

操作完驱动器,接着就是来操作文件夹了。其中包括:提取文件夹信息、创建文件夹、删除文件夹、复制文件夹、移动文件夹等。下面就具体来看。
  一、fso.GetFolder
  一看就明白,是提取文件夹了。那具体是提取哪个文件夹呢?后面肯定要跟一个文件夹的路径。提取出来了再来显示该文件夹相关信息呢?是不是有要具体提取下去。所以,看程序:
  1,getfldr.asp

<%Set fso = CreateObject("Scripting.FileSystemObject")
Set fldr = fso.GetFolder("c:\Program Files")
Response.Write "父文件夹名字是:" & fldr & "<br>"
If fldr.IsRootFolder = True Then 
Response.Write "该文件夹是一根文件夹" & "<br>"
Else 
Response.Write "该文件夹不是根文件夹" & "<br>" 
End If
Response.Write "驱动器名字是:" & fldr.Drive & "<br>"%>
  首先建立FSO组件的连接是必不可少的啦,然后Set fldr = fso.GetFolder("c:\Program Files")设定fldr对象被赋值,以作下面程序的引用。
  fldr.IsRootFolder即为判断该文件夹是否为一根文件夹,值为布尔值(true or false);fldr.Drive则显示该文件夹所在的驱动器号了。
  二、fso.CreateFolder
  下面比较让人激动的是通过ASP建立文件夹了,你可以在你的权力范围内任意位置建立任意文件夹。
  2,creatfldr.asp

<%Set fso = CreateObject("Scripting.FileSystemObject")
fso.CreateFolder ("c:\cnbruce")
Response.Write "文件夹名为" & fso.GetBaseName("c:\cnbruce")%>
  执行程序,应该发现C盘多出了cnbruce文件夹,fso.GetBaseName则是提取文件夹名。
  三、fso.DeleteFolder
  通过ASP可以建立了文件夹,则同样可以删除文件夹。
  3,delfldr.asp

<%Set fso = CreateObject("Scripting.FileSystemObject")
fso.DeleteFolder("c:\cnbruce")
Response.Write "文件夹已删除"%>
  发现刚建立的cnbruce文件夹确实已被删除。
 
  那下面就采用一个通用程序来灵活应变下。
  4,mainflr.asp

<%Sub CreateAFolder(file) 
Dim fso 
Set fso = CreateObject("Scripting.FileSystemObject") 
fso.CreateFolder(file) 
response.write "已经建立了"&file
End Sub
Sub DeleteAFolder(file) 
Dim fso 
Set fso = CreateObject("Scripting.FileSystemObject") 
fso.DeleteFolder(file) 
response.write "已经删除了"&file
End Sub%>
<%subname=request.form("submit")
create=request.form("create")
del=request.form("del")
if subname<>"" then
 if create<>"" then
  call CreateAFolder(""&create&"")
  end if
   if del<>"" then
    call DeleteAFolder(""&del&"")
   end if
end if%>
 <form action="mainflr.asp" method="post">
 <input name="create">
 <input type="submit" value="建立" name="submit">
 </form>
 <hr>
 <form action="mainflr.asp" method="post"><input name="del">
 <input type="submit" value="删除" name="submit">
 </form>
  需要注意的是:删除并不会提示“确认要放入回收站”这项。这点你需要谨慎处理,特别是对你的系统文件夹。

  四、fso.MoveFolder
  主要作用是进行文件夹的移动,相当于剪切粘贴动作。
  5,movefldr.asp

<%Set fso = CreateObject("Scripting.FileSystemObject")
fso.CreateFolder ("c:\cnbruce")
fso.MoveFolder "c:\cnbruce", "C:\Program Files\"%>
<a href="C:\Program Files\">查看cnbruce文件夹有没有移动过来</a>
  格式:fso.MoveFolder "被移动的文件夹","移动到的文件夹"
  本程序先是在C盘下建立了cnbruce文件夹,然后将其移动到C:\Program Files\文件夹下面。
  不过同样需要注意的是你的系统文件夹不能乱移动。
  五、fso.CopyFolder
  主要作用:将文件夹从某位置复制到另一位置。
  6,copyfldr.asp

<%Set fso = CreateObject("Scripting.FileSystemObject")
fso.CopyFolder "c:\Program Files\cnbruce", "c:\"%>
<a href="C:\">查看cnbruce文件夹有没有复制过来</a>
  该程序是建立在上一movefldr.asp的执行结果基础之上来完成复制到C盘根目录下的。(话比较长-_-!)
  当然,其拷贝也是将该文件夹包括里面所以子文件夹和文件统统拷贝。
  到最后再试着将c:\Program Files\cnbruce和c:\cnbruce两个文件夹进行删除掉吧。
  不过,继续提醒你:不要写错了,比如写成c:\Program Files,那你就惨了:这叫玩命,学ASP玩出心跳出来了。
  对文件夹的操作差不多了,是不是感到用处比较大?有训言:好东西是把双刃剑。正义和邪恶就只一线间,注意正规合理利用该组件。不过还有你放心的是,现在网站空间服务商对这权力已经限定得死死的了,你再怎么闹翻也不会冒泡的:)
  然后接下来就是更微妙的:FSO对文件的操作。
FSO中除了可以对驱动器、文件夹的操作以外,功能最强大的就是对文件的操作了。它可以用来记数、内容管理、搜索还可生成动态HTML页面等等。
  一、fso.OpenTextFile
  无需多说,fso.OpenTextFile就是打开某个文件了,一般情况之下是打开的txt文本文件。所以首先我们先建立一个txt文件,然后通过FSO来读取其中的内容。
  1,info.txt

name:cnbrucesex:male
  建立了该文件,下面再做个ASP页面,当然最好两个文件是在同一目录下。
  2,opentxt.asp

<%whichfile=server.mappath("info.txt")
Set fso = CreateObject("Scripting.FileSystemObject")
Set txt = fso.OpenTextFile(whichfile,1)
rline = txt.ReadLine
rline = rline & "<br>" & txt.ReadLine
Response.Write rlinetxt.Close%>
  需要注意:无论是通过FSO打开驱动器、打开文件夹、打开文件,以及以后要接触到的打开数据库,都只能是打开绝对物理路径地址。但一般情况是上传到空间服务商那,不能很直接地了解到自己文件的所在位置,所以强烈推荐使用server.mappath方法:平台移植性强,适用性强。
  CreateObject("Scripting.FileSystemObject")建立了FSO组件的连接,fso.OpenTextFile(whichfile,1)打开了info.txt该文件。参数“1”表示“ForReading:以只读方式打开文件。不能写这个文件。”,其他还有参数“2”表示“ForWriting:以写方式打开文件”,参数“8”表示“ForAppending:打开文件并从文件末尾开始写”。
  打开了该文件,接下来是不是要显示文件中的内容?那就通过txt.ReadLine方法读取文本中的一整行,如果需要继续读取下一行,则继续使用txt.ReadLine方法。当然初此还有其它的读取方法,比如txt.Read(7)读取指定数量的字符,txt.ReadAll返回文本中的全部内容。

  二、fso.CreateTextFile
  如fso.CreateFolder建立文件夹般,fso.CreateTextFile则是建立文件了。
  3,creattxt.asp

<%whichfile=server.mappath("info.txt")
Set fso = CreateObject("Scripting.FileSystemObject")
Set MyFile = fso.CreateTextFile(whichfile,True)
MyFile.WriteLine("My Name Is CN-Bruce")
MyFile.WriteLine("My Sex Is Male")
MyFile.Close%>
<a href="opentxt.asp">查看内容</a>
  本次建立的文件是上一info.txt文件,fso.CreateTextFile(whichfile,True)其中的参数true即表示能覆盖已有文件。建立后需要向里面添加数据就采用“MyFile.WriteLine”了。
  那现在就可以建立一个简单的文本记数器了,还记得以前的记数?:1,通过application、session、global.asa进行记数;2,通过Counter组件进行记数。但两者都有通病,就是不能保存,如果服务器重新启动后,是不是所有记数全部清空了呢:)那现在就可以使用文本来记录数据了,即使重启,下次提取的也还是该文件。
  试验:文本计数器
  首先建立一记数的文本文件counter.txt,设定初始值为“1”
  4,counter.txt

1
  接着是记数的ASP文件,功能是显示文本的记数,本做加1的记数,然后还要将新的记数写入文本文件。
  5,txtcount.asp

<%whichfile=server.mappath("counter.txt")’打开文件并将其值读取,最后关闭连接释放资源
set fso=createobject("Scripting.FileSystemObject")
set openfile=fso.opentextfile(whichfile,1)
visitors=openfile.readline
openfile.close’页面显示记数内容并做加1运算
response.write "您是本页的第"&visitors&"位访客"
visitors=visitors+1’将新的数值添加写入到文本,最后关闭所有连接释放资源
set creatfile=fso.createtextfile(whichfile)
creatfile.writeLine(visitors)
creatfile.close
set fso=nothing%>
  那根据这个可以继续地扩展内容:比如让记数用数字图片显示。当然前提就是你需要0-9的10张记数图片,并将此图片放于img文件夹中。
  下为一增强的txtcount.asp内容代码。

<%whichfile=server.mappath("counter.txt")
set fso=createobject("Scripting.FileSystemObject")
set openfile=fso.opentextfile(whichfile,1)
visitors=openfile.readline
openfile.close
CountLen=len(visitors)
response.write "您是本页的第"
for i=1 to 6-countLen ’表示最大值999999 
response.write "<img src=img/0.gif></img>"
next 
for i=1 to countlen 
response.write "<img src=img/" & mid(visitors,i,1) & ".gif></img>"
next
response.write "位访客"
visitors=visitors+1
set creatfile=fso.createtextfile(whichfile)
creatfile.writeLine(visitors)
creatfile.closeset
fso=nothing%>

  本程序中采用的是mid函数,该函数的作用是返回某字符串中从第几位字符开始的几个字符。格式即为:Mid(string,start,length)

<script language=vbs>
cn_string= "cnbruce love cnrose"
cn_start = 9
cn_length = 4
alert (mid(cn_string,cn_start,cn_length))
</script>
学会了FSO提取文件值,也学会了将信息输入到文件中,那下面就再来应用应用下。
  不知道你有没有这样的习惯:看到一个文件,不自觉的右键选择用记事本打开。呵呵,几乎没有哪个文件是不可以的。所以现在,可以默认所有文件都是文本,只是后缀名不同而已;那么也就是说,现在可以提取任一文件的内容信息。OK,就来想象一下:
  1,提取一个文件的路径(采用file按钮进行查找定位)
  2,将该路径文件打开,并读取所有行
  3,显示读取的信息
  一、viewcode.asp

<%Function ShowCode(filename) 
Set fso = Server.CreateObject("Scripting.FileSystemObject") 
Set cnrs = fso.OpenTextFile(filename, 1) 
While Not cnrs.AtEndOfStream 
rsline = cnrs.ReadLine 
rsline = server.HTMLEncode(rsline) 
Response.Write(rsline & "<br>") 
Wend
end Function%>
<form action="viewcode.asp" method="post">输入文件名
<input type="file" name="filename">
<input type="submit" value="查看源程序">
</form>
<%file=request.form("filename")
response.write (file & "源程序如下<hr>")
If trim(file)<> "" then 
Call ShowCode(file)
End If%>
  以上程序调试时,可以选择html,asp页面,也可以打开任一应用程序等。
  定义的ShowCode函数,主要作用是打开、读取并显示文件中所有信息内容。注意添加了server.HTMLEncode(rsline),针对含有标准HTML代码的文件。
  显示文件中所有行即用一条件循环进行遍历显示了。

While Not cnrs.AtEndOfStream…Wend

  接着,下面的这个例题具体就涉及open方法的问题了,还记得?正常情况之下打开文件是采用fso.OpenTextFile("c:\testfile.txt",1),参数1的作用是:以只读模式打开文件。不能对此文件进行写操作。如果现在已经存在一文件,需要进行追加写入,则该怎么办呢?简单,参数为8即可。
  这有什么用呢?呵呵,亚玛逊的网络故事接龙就是如此:能接龙就需要首先要显示原有故事,然后自己添加故事写入文件。这其中的写入文件最讲究的就是追加写入了。所以下面就可以实现。
  二、story.asp

<%If not request.Form("NextLine")="" then 
Set fso=Server.CreateObject("Scripting.FileSystemobject") 
textfile1=Server.MapPath("story.txt") 
set cnrs=fso.OpenTextFile(textfile1,8) 
cnrs.WriteLine(Request.Form("NextLine")) 
cnrs.Close
end if
%>故事如下:<%
Set fso=Server.CreateObject("Scripting.FileSystemObject")
textfile1=Server.MapPath("story.txt")
set cnrs=fso.OpenTextFile(textfile1,1)
while not cnrs.AtEndOfStream 
Response.Write " " & cnrs.ReadLinewend
cnrs.close%>
<hr>
<form method="post" action="story.asp">请输入这个故事的新行:
<input name="NextLine" type="text" size="70">
<input type="submit" value="提交"></form>
  整个就是一很简单的读取信息和加入信息的混合利用,相信有了前面的基础看懂应该不成问题。当然还缺少个story.txt文件,里面写好故事开头就可以了。
  调试
  再下面,继续来,该侧重点主要就是练习一些函数的使用技巧了。
  1,instr函数:返回某字符串在另一字符串中第一次出现的位置。
  比如现在查找字母“A”在字符串“A110B121C119D1861”中第一次出现的位置,则可以

<script language=vbs>
my_string = "A110B121C119D1861"
a_num = instr(my_string,"A")
alert(a_num)
</script>
  同样字母“B”的位置也就能确定。现在就来最关键的:提前字母“A”和“B”中间的值“110”。
  还记得mid函数吗?mid函数的主要作用是:从字符串中返回指定数目的字符。
  比如现在的“110”则应该是从字符串的第2位取得3个单位的值。

<script language=vbs>
my_string = "A110B121C119D1861"
a_value = mid(my_string,2,3)
alert(a_value)
</script>
  但设想一下:如果不是“110”,而是“1100”,那是不是要提取4位……这样就显出程序的不够完美。
  所以继续思考:所提取的值,永远是在字母“A”后面的,且值也永远是在字母“A”和“B”之间的,那么只要分别提取出“A”、“B”的位置,则中间数值的起始位应是字母“A”位+1,中间数值的长度应是字母“B”位-字母“A”位-1
  那么现在就可以让程序完美起来:

<script language=vbs>
my_string = "A110B121C119D1861"
a_num = instr(my_string,"A")
b_num = instr(my_string,"B")
a_value = mid(my_string,a_num+1,b_num-a_num-1)
alert(a_value)
</script>
  OK,那么现在你也就完全可以把字母“B”、“C”、“D”后面的值一一提取了。
  当然需要注意的就是“D”后面有几位怎么取呢?采用字符串总长度-字母D所在位置数就可以了。
<script language=vbs>
my_string = "A110B121C119D1861"
a_num = instr(my_string,"A")
b_num = instr(my_string,"B")
c_num = instr(my_string,"C")
d_num = instr(my_string,"D")
total_num = len(my_string)
a_value = mid(my_string,a_num+1,b_num-a_num-1)
b_value = mid(my_string,b_num+1,c_num-b_num-1)
c_value = mid(my_string,c_num+1,d_num-c_num-1)
d_value = mid(my_string,d_num+1,total_num-d_num)
alert(a_value)
alert(b_value)
alert(c_value)
alert(d_value)
</script>

  用到现在,你也许确实学到了不少,但也许会提出疑问:这个放在FSO文件操作里有什么作用呢?
  那下面才是我们的正题:用FSO进行简单的文本投票。
  投票页面首要的就是显示各类项目的投票数,并相应赋于某个变量。然后判断本次投票的选相,相对应地将投票数值加1,完毕后再将所有值继续写入文本。
  1,一个HTML表单页website.html
  以做投票点击的平台。
用到现在,你也许确实学到了不少,但也许会提出疑问:这个放在FSO文件操作里有什么作用呢?
那下面才是我们的正题:用FSO进行简单的文本投票。

<form action="result.asp" method="post">
<input type="radio" name="website" value="A" checked> cnbruce.com<br><input type="radio" name="website" value="B"> blueidea.com<br><input type="radio" name="website" value="C"> it365cn.com<br><input type="radio" name="website" value="D"> 5d.cn<br><input type="submit"><input type="reset">
  2,接受表单页值的result.asp

<%whichfile=server.mappath("site.txt")
set fso=createobject("Scripting.FileSystemObject")
set thisfile=fso.opentextfile(whichfile)
my_string=thisfile.read
linea_num = instr(my_string,"A")
b_num = instr(my_string,"B")
c_num = instr(my_string,"C")
d_num = instr(my_string,"D")
total_num = len(my_string)
a_value = mid(my_string,a_num+1,b_num-a_num-1)
b_value = mid(my_string,b_num+1,c_num-b_num-1)
c_value = mid(my_string,c_num+1,d_num-c_num-1)
d_value = mid(my_string,d_num+1,total_num-d_num)
select case request.form("website") 
case "A": a_value=a_value+1 
case "B": b_value=b_value+1 
case "C": c_value=c_value+1 
case "D": d_value=d_value+1
end select
mynew_string="A" & cstr(a_value) & "B" & cstr(b_value) & "C" & cstr(c_value) & "D" & cstr(d_value)
set newfile=fso.createtextfile(whichfile)
newfile.writeLine(mynew_string)
newfile.closeset fso=nothing%>当前投票:<br>cnbruce.com:<%=a_value%>
<br>blueidea.com:<%=b_value%><br>
it356cn.com:<%=c_value%><br>
5d.cn:<%=d_value%><br>
<a href="website.html">返回继续</a>
  有了上面函数的基础,看这个应该不是很难的。
  3,最后不要忘了的记数文件site.txt
  格式:A1B1C1D1
  调试
  OK,三个文件就可以胜任一个很简单的投票系统了,如果要加强,需要细化的则结合以前的知识吧,比如投过一次后设置session或者cookies,当再次投票时候判断如果session或者cookies存在则不允许,也就是简单的投票防作假手段了……当然更多的还是要自己去想去实践了。

 一,fso.GetFile
  提取文件相应的 File 对象
  1,getfile.asp

<%whichfile=Server.MapPath("cnbruce.txt")
Set fso = CreateObject("Scripting.FileSystemObject")
Set f1 = fso.CreateTextFile(whichfile,true)
f1.Write ("This is a test.My Name is cnbruce.")
f1.CloseSet f2 = fso.GetFile(whichfile) 
s = "文件名称:" & f2.name & "<br>"
s = s & "文件短路径名:" & f2.shortPath & "<br>"
s = s & "文件物理地址:" & f2.Path & "<br>"
s = s & "文件属性:" & f2.Attributes & "<br>"
s = s & "文件大小: " & f2.size & "<br>"s = s & "文件类型: " & f2.type & "<br>"
s = s & "文件创建时间: " & f2.DateCreated & "<br>"
s = s & "最近访问时间: " & f2.DateLastAccessed & "<br>"
s = s & "最近修改时间: " & f2.DateLastModified
response.write(s)%>
  其效果正如右键某文件,看到的具体属性信息。
  其中Attributes返回的数值“32”表示:(Archive)上次备份后已更改的文件。可读写。
  其它值附录如下:

Normal 0 普通文件。 没有设置任何属性。 
ReadOnly 1 只读文件。 可读写。 
Hidden 2 隐藏文件。 可读写。 
System 4 系统文件。 可读写。 
Directory 16 文件夹或目录。 只读。 
Archive 32 上次备份后已更改的文件。 可读写。 
Alias 1024 链接或快捷方式。 只读。 
Compressed 2048 压缩文件。 只读。 
  二,file.move
  作用将指定的文件或文件夹从某位置移动到另一位置。其实该方法仍然属于fso.GetFile后的一个应用。
  2,movefile.asp
<%whichfile=Server.MapPath("cnbruce.txt")
Set fso = CreateObject("Scripting.FileSystemObject")
Set f1 = fso.CreateTextFile(whichfile,true)
f1.Write ("This is a test.My Name is cnbruce.")
f1.CloseSet f2 = fso.GetFile(whichfile)
f2.Move "C:\"%>
<a href="C:\">查看下有没有</a>
  简单的剪切粘贴的功能实现。
  三,File.Copy
  同样属于fso.GetFile后的一个应用。就只是单纯地拷贝文件到某位置。
  3,copyfile.asp

<%whichfile=Server.MapPath("cnbruce.txt")
Set fso = CreateObject("Scripting.FileSystemObject")
Set f1 = fso.CreateTextFile(whichfile,true)
f1.Write ("This is a test.My Name is cnbruce.")
f1.CloseSet f2 = fso.GetFile(whichfile)
f2.Copy "D:\"%>
<a href="D:\">查看下有没有</a>
  和本ASP页面同在目录下的cnbruce.txt文件依然存在。

  四,file.Delete
  很显然,就是直接删除文件了。
  4,delfile.asp

<%whichfile=Server.MapPath("cnbruce.txt")
Set fso = CreateObject("Scripting.FileSystemObject")
Set f1 = fso.CreateTextFile(whichfile,true)
f1.Write ("This is a test.My Name is cnbruce.")
f1.Close
Set f2 = fso.GetFile(whichfile)
f2.move "d:\"Set
 f3 = fso.GetFile("d:\cnbruce.txt")
f3.delete 
%>
<a href="d:\">查看下是没有该文件的</a>
  当然FSO还没有结束,比如上传文件,ASP转HTML等都需要用到FSO。

2006年05月10日

Function ReadToEnd(strURL)
 Set fileSysObj = createObject("Scripting.FileSystemObject")
 IF (fileSysObj.FileExists( server.mappath(strURL) )) Then
 
  ’ if the file exists, then open it for reading
  Set tf = filesysobj.OpenTextFile( server.mappath(strURL) , 1)
  while (tf.AtEndOfStream = false)
   read = read &  tf.ReadLine & "\n"
   
  wend
   Response.write "<script>alert(‘" &  read & "’)</script>"
   Response.end()
  tf.Close

  
 ELSE
  ’ if you can’t find read.text, display default message
  read = "I can’t find the file read.txt! So this is my default message."
 END IF

End Function

2006年03月22日

parseInt   方法
请参阅
isNaN   方法   |   parseFloat   方法   |   String   对象   |   valueOf   方法

应用于:   Global   对象
要求
版本   1
返回由字符串转换得到的整数。

parseInt(numString,   [radix])
参数
numString  
必选项。要转换为数字的字符串。  
radix  
可选项。在   2   和   36   之间的表示   numString   所保存数字的进制的值。如果没有提供,则前缀为   ‘0x’   的字符串被当作十六进制,前缀为   ‘0′   的字符串被当作八进制。所有其它字符串都被当作是十进制的。  
说明
parseInt   方法返回与保存在   numString   中的数字值相等的整数。如果   numString   的前缀不能解释为整数,则返回   NaN(而不是数字)。

parseInt("abc")           //   返回   NaN。
parseInt("12abc")       //   返回   12。
可以用   isNaN   方法检测   NaN。

加入一个用JS格式化日期性的东东

formatDate(new Date(getDateFromFormat(document.Master.dateto.value,D-M-Y),’yyyy-M’);