自動化ツール(コード生成パターン抽出)

Posted fff8965

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自動化ツール(コード生成パターン抽出)相关的知识,希望对你有一定的参考价值。

コード生成:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <script src="https://code.jquery.com/jquery-3.2.1.min.js"
            integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4="
            crossorigin="anonymous"></script>
    <script>

        function _exeInputValue() {
            var inputText = $("#inputText").val();
            var inputLines = inputText.split("\n");
            var inputGridValues = [];
            for (var i = 0 ; i < inputLines.length; i++) {
                var line = inputLines[i];
                if (line.length > 0) {
                    var values = line.split("\t");
                    var lineValues = [];

                    for (var j = 0 ; j < values.length ; j++) {
                        lineValues.push(values[j]);
                    }

                    inputGridValues.push(lineValues);
                }
            }

            return inputGridValues;
        }

        function _exeInputView(inputGridValues)
        {
            var table = $("<table class=‘outputViewTable‘>");
            for (var i = 0 ; i < inputGridValues.length ; i++) {
                var lineValues = inputGridValues[i];

                if (i == 0) {
                    var tr = $("<tr class=‘w3-green‘>");
                    for (var j = 0 ; j < lineValues.length; j++) {
                        var value = lineValues[j];

                        var td = $("<td class=‘w3-border-white‘>");
                        td.html(‘{‘ + j + ‘}‘);

                        tr.append(td);
                    }
                    table.append(tr);
                }

                var tr = $("<tr>");
                for (var j = 0 ; j < lineValues.length; j++) {
                    var value = lineValues[j];

                    var td = $("<td>");
                    td.html(value);

                    tr.append(td);
                }
                table.append(tr);
            }

            $("#inputView").empty().append(table);
        }

        function _exeOutputCode(inputGridValues) {
            var template = $("#inputTemplate").val();

            var outputText = [];

            for (var i = 0 ; i < inputGridValues.length; i++) {
                var lineValues = inputGridValues[i];

                var text = template;
                for (var j = 0 ; j < lineValues.length; j++) {
                    var value = lineValues[j];
                    text = text.replace("{" + j + "}", value);
                }

                outputText.push(text);
            }

            $("#outputText").val(outputText.join("\n"));
        }

        function codeOutput() {
            
            var inputGridValues = _exeInputValue();

            _exeInputView(inputGridValues);

            _exeOutputCode(inputGridValues);
        }
    </script>
    <link rel="stylesheet" href="https://www.w3schools.com/w3css/4/w3.css">
    <style>
        *{
            box-sizing:border-box;
        }
        body{
            overflow:hidden;
        }
        table{
            border-collapse:collapse;
        }
        .absoluteBase {
            position: absolute;
            top: 0px;
            bottom: 0;
            left: 0;
            right: 0;
        }
        div {
            /*border: 1px solid green;*/
        }
        .leftTop {
            bottom: 50%;
            right: 50%;
        }
        .rightTop {
            bottom: 50%;
            left: 50%;
        }
        .bottom {
            top: 50%;
        }
        .relativeRoot {
            position: relative;
            height: 100%;
            width: 100%;
        }
        .title {
            padding: 8px;
            font-size: 20px;
            font-family: "Segoe UI",Arial,sans-serif;
        }
        #inputView,#outputView{
            padding:5px;
            overflow:scroll;
        }
        textarea{
            border:none;
        }
        button{
            height:35px;
        }
        .outputViewTable td {
            border: 1px solid #4CAF50;
            padding: 5px 8px;
        }
    </style>
</head>
<body>
    <div style="height:35px;">
        <button onclick="codeOutput();">コード生成</button>
    </div>
    <div style="position:absolute;top:35px;bottom:2px;left:0;right:0;border:1px solid black;">
        <div class="relativeRoot">
            <div class="absoluteBase leftTop w3-border">
                <div class="relativeRoot">
                    <div class="absoluteBase" style="bottom:50%">
                        <div class="title w3-teal" style="height:50px;">
                            入力値
                        </div>
                        <div class="absoluteBase" style="top:50px">
                            <textarea id="inputText" style="width:100%;height:100%">a1	b1	c1
a2	b2	c2
a3	b3	c3</textarea>
                        </div>
                    </div>
                    <div class="absoluteBase" style="top:50%;">
                        <div class="title w3-teal" style="height:50px;">
                            入力テンプレート
                        </div>
                        <div class="absoluteBase" style="top:50px">
                            <textarea id="inputTemplate" style="width:100%;height:100%">//{0}
public string {1}; //{2}
</textarea>
                        </div>
                    </div>
                </div>
            </div>
            <div class="absoluteBase rightTop w3-border">
                <div class="relativeRoot">
                    <div class="title w3-teal" style="height:50px;">
                        入力値可視化
                    </div>
                    <div id="inputView" class="absoluteBase" style="top:50px">
                        
                    </div>
                </div>
            </div>
            <div class="absoluteBase bottom w3-border" >
                <div class="relativeRoot">
                    <div class="title w3-teal" style="height:50px;">
                        出力テキスト
                    </div>
                    <div class="absoluteBase" style="top:50px">
                        <textarea id="outputText" style="width:100%;height:100%"></textarea>
                    </div>
                </div>
            </div>
        </div>
    </div>
</body>
</html>

  パターン抽出:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <script src="https://code.jquery.com/jquery-3.2.1.min.js"
            integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4="
            crossorigin="anonymous"></script>
    <script>

        function _exeOutputView(arr)
        {
            var table = $("<table class=‘outputViewTable‘>");
            for (var i = 0 ; i < arr.length ; i++) {
                var lineValues = arr[i];

                if (i == 0) {
                    var tr = $("<tr class=‘w3-green‘>");
                    for (var j = 0 ; j < lineValues.length; j++) {
                        var value = lineValues[j];

                        var td = $("<td class=‘w3-border-white‘>");
                        td.html(‘{‘ + j + ‘}‘);

                        tr.append(td);
                    }
                    table.append(tr);
                }

                var tr = $("<tr>");
                for (var j = 0 ; j < lineValues.length; j++) {
                    var value = lineValues[j];

                    var td = $("<td>");
                    td.html(value);

                    tr.append(td);
                }
                table.append(tr);
            }

            $("#outputView").empty().append(table);
        }

        function _exeOutputCode(arr) {

            var outputText = [];

            for (var i = 0 ; i < arr.length; i++) {
                var lineValues = arr[i];

                var text = "";
                for (var j = 0 ; j < lineValues.length; j++) {
                    var value = lineValues[j];
                    if (j != 0) {
                        text += ‘\t‘;
                    }
                    text += value;
                }

                outputText.push(text);
            }

            $("#outputText").val(outputText.join("\n"));
        }

        function codeOutput(matchFromFirst) {
            
            var resultArray = [];

            var text = $("#inputText").val();

            var regexText = $("#inputRegex").val();

            var regex = new RegExp(regexText, "g");

            if (!text || !regexText) {
                return;
            }

            var result = regex.exec(text);
            while (result) {
                var arr = [];
                var i = 0;
                if (matchFromFirst == false) {
                    i = 1;
                }
                for ( ; i < result.length ; i++) {
                    arr.push(result[i]);
                }
                resultArray.push(arr);
                result = regex.exec(text);
            }
            //var mm = regex.exec(text);
            //var m = text.match(regex);

            _exeOutputCode(resultArray);
            _exeOutputView(resultArray);
        }
    </script>
    <link rel="stylesheet" href="https://www.w3schools.com/w3css/4/w3.css">
    <style>
        *{
            box-sizing:border-box;
        }
        table{
            border-collapse:collapse;
        }
        .absoluteBase {
            position: absolute;
            top: 0px;
            bottom: 0;
            left: 0;
            right: 0;
        }
        div {
            /*border: 1px solid green;*/
        }
        .leftTop {
            bottom: 50%;
            right: 50%;
        }
        .rightTop {
            bottom: 50%;
            left: 50%;
        }
        .leftBottom {
            top: 50%;
            right: 50%;
        }
        .rightBottom {
            top: 50%;
            left: 50%;
        }
        .relativeRoot {
            position: relative;
            height: 100%;
            width: 100%;
        }
        .title {
            padding: 8px;
            font-size: 20px;
            font-family: "Segoe UI",Arial,sans-serif;
        }
        #inputView,#outputView{
            padding:5px;
            overflow:scroll;
        }
        textarea{
            border:none;
        }
        button{
            height:35px;
        }
        .outputViewTable td {
            border: 1px solid #4CAF50;
            padding: 5px 8px;
        }
    </style>
</head>
<body>
    <div style="height:35px;">
        <button onclick="codeOutput(true);">パターン抽出(0含む)</button>
        <button onclick="codeOutput(false);">パターン抽出(0含まない)</button>
    </div>
    <div style="position:absolute;top:35px;bottom:0;left:0;right:0;border:1px solid black;">
        <div class="relativeRoot">
            <div class="absoluteBase leftTop w3-border">
                <div class="relativeRoot">
                    <div class="title w3-teal" style="height:50px;">
                        入力値
                    </div>
                    <div class="absoluteBase" style="top:50px">
                        <textarea id="inputText" style="width:100%;height:100%">//a1
public string b1; //c1

//a2
public string b2; //c2

//a3
public string b3; //c3
</textarea>
                    </div>
                </div>
            </div>
            <div class="absoluteBase rightTop w3-border">
                <div class="relativeRoot">
                    <div class="title w3-teal" style="height:50px;">
                        Regex
                    </div>
                    <div class="absoluteBase" style="top:50px">
                        <textarea id="inputRegex" style="width:100%;height:100%">//(.+)\n.*public string (.+); //(.+)</textarea>
                    </div>
                </div>
            </div>
            <div class="absoluteBase leftBottom w3-border">
                <div class="relativeRoot">
                    <div class="title w3-teal" style="height:50px;">
                        出力テキスト
                    </div>
                    <div class="absoluteBase" style="top:50px">
                        <textarea id="outputText" style="width:100%;height:100%"></textarea>
                    </div>
                </div>
            </div>
            <div class="absoluteBase rightBottom w3-border">
                <div class="relativeRoot">
                    <div class="title w3-teal" style="height:50px;">
                        出力値可視化
                    </div>
                    <div id="outputView" class="absoluteBase" style="top:50px">

                    </div>
                </div>
            </div>
        </div>
        
    </div>
</body>
</html>

  

以上是关于自動化ツール(コード生成パターン抽出)的主要内容,如果未能解决你的问题,请参考以下文章

markdown モジュールパターン#1

csharp シェーダのコンパイル部分コード

ruby テキストから日本语を抜き出す正规表现。失败パターン,成功パターン

csharp 顶点バッファ生成部分コード

csharp SlimDX回転行列を生成してそれをシェーダに渡す部分コード

csharp ビューポート设定部分コード