블로그 이미지
JinStudio의 아이디어와 정보를 모아놓는 블로그.
JinStudio

공지사항

최근에 올라온 글

최근에 달린 댓글

글 보관함

calendar

1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31

* 조건에 따른 색상 설정.
    초기화 과정에서는 그런 기능은 없습니다. 따라서 조회 XML안에 TR,TD에 속성을 넣으시거나 조회 후 현재와 같이 스크립트를 통해 주는 방법 밖에는 없습니다. 여기서 약간의 팁을 드리자면 보통 이런 작업을 할때는 스크립트와 시트 객체간의 호출이 많아질 수로 속도가 느려지게 됩니다. 따라서 최대한 속도를 빠르게 하기 위해서는 연산이 필요한 부분은 한번에 스크립트로 가져와 연산하고 이후 한꺼번에 반영하는 것이 좋습니다.

간단한 예를 보여드리자면 아래와 같습니다.

속도가 느려지는 작업 예)
for(var i=0;i<mySheet.LastRow;i++){
    if(mySheet.CellValue(i,8)<300){
        mySheet.CellFontColor(i,8) = mySheet.WebColor("#FF0000");
    }
}

속도가 빠른 작업 예)
//8번 컬럼의 전체 데이터를 string 형태로 받는다.
var data = mySheet.GetRangeValue(0,8,mySheet.LastRow,8);


//스크립트 안에서 모두 작업한다.
var dataArr = data.split("^");
var rtnArr = new Array();
for(var i=0;i<dataArr.length;i++){
    if(dataArr[i]<300){
        //300 보다 작은 값은 모두 rtnArr배열에 넣는다.
        rtnArr.push(i);
    }
}


//한번에 시트에 반영하기 위해 받은 내용을 갖고 XML을 만든다.
var xmlstr = "<?xml version='1.0'?><sheet><data>";
for(var i=0;i<rtnArr.length;i++){
    xmlstr += "<TR ROW='"+rtnArr[i]+"' COL='8'><TD COLOR='RED'></TD></TR>";
}
xmlstr += "</data></sheet>";

//만들어진 xml을 한번에 반영한다.
mySheet.LoadSearchXml(xmlstr , false, -1,true);

출처 : http://www.ibleaders.co.kr/