WPS的JS宏基础(一)

基础知识

1、简单的第一个宏

javascript 复制代码
//注意function只能全部用小写
function demo(){
	alert("你好!")
}

2、录制宏生成工资条

javascript 复制代码
function 使用录制宏自动生成代码以JS宏为例()//使用相对引用
{
	Selection.Copy(undefined);
	ActiveCell.Offset(5, 0).Range("A1:M4").Insert(xlShiftDown, undefined);
	Application.CutCopyMode = false;
	ActiveCell.Offset(5, 0).Range("A1:M4").Select();
}


3、JS宏的基础语句

循环语句

javascript 复制代码
function test1(){
	for(var txt of ["春花","秋月","夏风","冬雪"]){
		Console.log(txt)
	}
}
javascript 复制代码
function test2(){
	for(var txt of "java"){//注意这里是逐字母输出
		console.log(txt)
	}
}
javascript 复制代码
function test3()//输出所有工作表名称
{
	for(var shs of Sheets){
		Console.log(shs.Name)
	}
}

分支语句

javascript 复制代码
function test6(){
	for(var sc of Range("a2:b17").Value2){
		Console.log(sc[0]+" = "+sc[1]+"分")//数组的第一序列数为0
		if(sc[1]>=90){
			Console.log("优异")
		}else{
			Console.log("普通")
		}
	}
}

4、基础应用

批量创建工作表、工作簿

javascript 复制代码
function 批量创建工作表2(){
	for (var xingming of Range("a2:a17").Value2){
		if (xingming != ""){
			Worksheets.Add();
			ActiveSheet.Name = xingming[0]
		}
	}
}
javascript 复制代码
function 批量创建工作簿2(){
	for(var jijie of ["春花","秋月","冬雪"]){
		Workbooks.Add();
		ActiveWorkbook.SaveAs("C:/Users/54240/Desktop/新建文件夹/"+jijie);
		//注意是右斜杆,如果是左斜杠应该写成-C:\\Users\\54240\\Desktop\\新建文件夹\\
		ActiveWorkbook.Close()
	}
}
javascript 复制代码
function 批量拆分工作表到工作簿(){
	for (var sh of Sheets){
		sh.Copy();'如果没有指定工作簿,则会自动创建一个新的工作簿'
		ActiveWorkbook.SaveAs("C:/Users/54240/Desktop/新建文件夹/"+sh.Name);
		ActiveWorkbook.Close();
	}
}

判断单元格数据

javascript 复制代码
function test(){
	var Arr1=[];
	var Arr2=[];
	var Arr3=[];
	var Arr4=Range("A2:b17").Value();
	for (var ar of Arr4){
		if (ar[1]>=60){
			Arr1.push(ar);//追加到后面
			Arr2.unshift(ar)//追加到前面
			Arr3.splice(Arr3.length,0,ar)
			//splice()
		}
	}
	if(Arr1.length == 0 || Arr2.length == 0){	//也可以用arr1 == false
		//JS的与(&&)或(||)非(!)
		//JS的=(==)不等于(!=)
		alert("没有数值!")
	}else{
		Range("d2").Resize(Arr1.length,2).Value2= Arr1	//注意arr1为空值的话会出错
		Range("f2").Resize(Arr2.length,2).Value2 = Arr2
		Range("h2").Resize(Arr3.length,2).Value2 = Arr3
	}

}

splice用法
push用法
unshift用法

5、JS变量的申明与赋值

变量就是内存中的一块存储空间,这个空间存储的就是变量的值。为这块空间贴个标签,这个标签就是变量名。三种声明变量的方式:const、var、let、

const 常量

let 变量申明(作用域更小)

var 变量申明(作用域更大)

var a; //申明单个变量

var b,c,d; //申明多个变量

var e=1,f=2,g=3.2 //申明多个变量并赋值数据类型

变量命名方法 示例1 示例2
匈牙利命名法 sName sMingZi
骆驼式命名法 smallFullName xiaoQianMing
帕斯卡命名法 SmallFullName XiaoQianMing
javascript 复制代码
	const pi=3.14;
	Console.log(pi*10);

	let a=10;
	var b=20;
	Console.log(a);
	Console.log(b);
	
	
	{
		let c=1;//let申明的变量作用范围只能在括号里面
		var d=2;
		Console.log(c);
		Console.log(d);
	}
	Console.log(c);
	Console.log(d);

var e;
var f,g,h;
var i=1,j=2,k=3;

var sName="小曾";
let sMingZi="小曾";
相关推荐
乌啼霜满天2496 分钟前
JDBC编程---Java
java·开发语言·sql
Myli_ing16 分钟前
考研倒计时-配色+1
前端·javascript·考研
色空大师19 分钟前
23种设计模式
java·开发语言·设计模式
余道各努力,千里自同风19 分钟前
前端 vue 如何区分开发环境
前端·javascript·vue.js
PandaCave26 分钟前
vue工程运行、构建、引用环境参数学习记录
javascript·vue.js·学习
软件小伟28 分钟前
Vue3+element-plus 实现中英文切换(Vue-i18n组件的使用)
前端·javascript·vue.js
Bruce小鬼31 分钟前
QT文件基本操作
开发语言·qt
2202_7544215437 分钟前
生成MPSOC以及ZYNQ的启动文件BOOT.BIN的小软件
java·linux·开发语言
我只会发热44 分钟前
Java SE 与 Java EE:基础与进阶的探索之旅
java·开发语言·java-ee
醉の虾1 小时前
Vue3 使用v-for 渲染列表数据后更新
前端·javascript·vue.js