आविष्कारक की मात्रात्मक रसायन विज्ञान डायरी (२) (समाप्त)

लेखक:छोटे सपने, बनाया गयाः 2016-05-22 20:05:36, अद्यतन किया गयाः 2019-08-01 10:31:58

पिछले कुछ दिनों में, कुछ समस्याओं को हल करने के बाद, ग्राहकों को कोड लिखने के दौरान, मुझे लगता है कि एक चार्ट टेम्पलेट लिखना आवश्यक है, जो संकेतकों (विशेष रूप से अपने स्वयं के लिखे गए संकेतकों) को दिखाता है, व्यापार स्थान आदि। क्योंकि मैं खुद भी एक शुरुआती छात्र हूं, उच्च चार्ट के लिए परिचित नहीं हूं, लेकिन एक वस्तु के वायदा के उदाहरण को देखा है।

सवाल 1:

 var ChartObj = {//画图
    tooltip: {xDateFormat: '%Y-%m-%d %H:%M:%S, %A'},
    chart: { zoomType:'x',panning:true },//图表类型  
    title: { text: ''}, //标题
    rangeSelector: {
            buttons:  [{type: 'hour',count: 1, text: '1h'}, {type: 'hour',count: 3, text: '3h'}, {type: 'hour', count: 8, text: '8h'}, {type: 'all',text: 'All'}],
            selected: 0,
            inputEnabled: false
        },
    subtitle: {text: " "},//副标题
    xAxis:{type: 'datetime'},
    yAxis: [{
            title: {text: 'K线'},//标题
            style: {color: '#4572A7'},//样式 
            opposite: false  //生成右边Y轴
        },
       {
            title:{text: 'WT'},
            opposite: true  //生成右边Y轴  ceshi
       }
    ],
    series: [//系列
        {name:'wt1',type:'spline',yAxis:1,data:[]},
        {type:'candlestick',yAxis:0,name:'K',id:'wt',data:[]},
        {name:'wt2',type:'spline',yAxis:1,data:[]},
        {type:'flags',onSeries:'wt',data:[]}
        ]                  
};
var chart = Chart(ChartObj);
var isFirst = true;
var preRecordTime = 0;
function Draw(){
    var strState = "";
    var fcolor = "";
    var msg = "";
    getRecords();
    if(isFirst === true){
        chart.reset();
        isFirst = false;
        preRecordTime = globalRecords[globalRecords.length - 1].Time;
    }
    if(preRecordTime === globalRecords[globalRecords.length - 1].Time){
        chart.add([1,[globalRecords[globalRecords.length - 1].Time,globalRecords[globalRecords.length - 1].Open,globalRecords[globalRecords.length - 1].High,globalRecords[globalRecords.length - 1].Low,globalRecords[globalRecords.length - 1].Close ],-1]);
    }else{
        //更新前一柱
        chart.add([1,[globalRecords[globalRecords.length - 2].Time,globalRecords[globalRecords.length - 2].Open,globalRecords[globalRecords.length - 2].High,globalRecords[globalRecords.length - 2].Low,globalRecords[globalRecords.length - 2].Close ],-1]);

        chart.add([1,[globalRecords[globalRecords.length - 1].Time,globalRecords[globalRecords.length - 1].Open,globalRecords[globalRecords.length - 1].High,globalRecords[globalRecords.length - 1].Low,globalRecords[globalRecords.length - 1].Close ]]);
       
        preRecordTime = globalRecords[globalRecords.length - 1].Time;
    }
    chart.update(ChartObj);
    //chart.reset(500);
}

कोड चिपकाने के लिए बुरा है ~ यह तुलनात्मक रूप से अंधा हो सकता है, आप इसे चिपका सकते हैं और sublime text के अंदर देख सकते हैं, सबसे पहले बस यह कहना है कि समस्या यह है कि कोड लिखने के बाद एक अजीब दृश्य है, यह देखेंः

यह अजीब है, प्रगति पट्टी 100% तक जाती है, हमेशा अटकती रहती है, स्थिर रहती है, नकली मौत नहीं होती है, यह अटक जाती है। मैंने परीक्षण करने के लिए विभिन्न तरीकों का भी उपयोग किया है, जैसे किः चक्रों की संख्या को सीमित करना, चक्रों की संख्या दिखाना, जो दिखाया गया है वह अंतिम चक्र तक चलता है। मैंने प्रोग्राम कोड देखा और मुझे लगा कि कोई समस्या नहीं होनी चाहिए। बेस्ट ने इसे हल नहीं किया। मैंने इसे पूरा किया, लंबे समय तक काम किया, और अंत में समस्या का पता लगाया, इसका कारण यह है। चार्ट को आरंभ करते समय, मैं डेटा अनुक्रम को इस तरह लिखता हूंः

 series: [//系列
        {name:'wt1',type:'spline',yAxis:1,data:[]},        //    索引为0的 数据项,   
        {type:'candlestick',yAxis:0,name:'K',id:'wt',data:[]},  // 索引为1
        {name:'wt2',type:'spline',yAxis:1,data:[]},    //索引为2
        {type:'flags',onSeries:'wt',data:[]}   //......
        ] 

इस तरह से प्रोग्राम में डेटा को चार्ट में लिखा जाता हैः

  chart.add([1,[globalR.........    (太长了 没写完)      //   可以看到这里 我写入索引为1 的数据序列,就是add后面[ 符号后的 1,代表写入到{type:'candlestick',yAxis:0,name:'K',id:'wt',data:[]},  这个序列中。问题就在这,我越过了索引0,直接写入索引1的数据序列里,就会导致卡死。

तो मैंने इसे बदल दियाः

  series: [//系列
        {type:'candlestick',yAxis:0,name:'K',id:'wt',data:[]},
        {name:'wt2',type:'spline',yAxis:1,data:[]},
        {type:'flags',onSeries:'wt',data:[]}
        ]  

सभी कोड जो डेटा को चार्ट में लिखते हैं (मुख्य रूप से 1 को 0 में बदलना)

 chart.add([0,[globalRecords[globalRecords.length - 1].Time,globalRecords[globalRe..........(太长了。。。)

यह अद्भुत है, यह चिपके नहीं है, यह काम करता है। हालांकि मुझे नहीं पता कि इसका कारण क्या है, लेकिन मुझे लगता है कि यह ग्राफ लाइब्रेरी में एक समस्या होनी चाहिए।


प्रश्न 2

आज के पोस्ट को अपडेट किया गया है, क्योंकि समूह में कुछ दोस्तों ने सवाल उठाए हैं, इसलिए शोध, समस्या निवारण और विशेष रूप से रिकॉर्डिंग के माध्यम से। यदि किसी नए उपयोगकर्ता के पास इसी तरह के प्रश्न हैं, तो इसे समझाने में आसान है। ठीक है, सवाल इस प्रकार हैः

getticker ने वायदा कीमतों को प्राप्त किया है क्यों यह वास्तविक कीमतों से अलग है?img

मैंने खुद का परीक्षण किया, वास्तव में अलग है आविष्कारक को क्वांटिफाइड करें रोबोट एक्सचेंज ओके फ्यूचर्स हैं, GetTicker का उपयोग करके प्राप्त नवीनतम बाजार की कीमतें वास्तव में ओके फ्यूचर्स की आधिकारिक वेबसाइट से अलग हैं, वास्तव में अजीब है, निश्चित रूप से कौन सा नहीं पता चला है। इस तरह के एक परीक्षण के लिए कोड का एक टुकड़ा लिखा गया हैः

function main(){
    exchange.SetContractType("this_week");
    var ticker = exchange.GetTicker();
    var huilv = exchange.GetRate();
    var OKhuilv = exchange.GetUSDCNY();
    while(true){
        huilv = exchange.GetRate();
        ticker = exchange.GetTicker();
        OKhuilv = exchange.GetUSDCNY();
        LogStatus("ticker:",ticker,"\n","huilv",huilv,"OKhuilv",OKhuilv);
        Sleep(1000);
    }
}

यह कैसे काम करता हैःimg imgमैंने दो अलग-अलग एपीआई फ़ंक्शनों का उपयोग करके एक्सचेंज दरें प्राप्त कीं।imgएपीआई के बारे में देखें, क्या ओके फ्यूचर्स अपने स्वयं के विनिमय दर का उपयोग करते हैं?

एक बार जब आप अपने हाथों से गणना करते हैं और सत्यापित करते हैं, तो परिणाम सीधे चार्ट पर आते हैंःimgजैसा कि ओके के आधिकारिक वेबसाइट पर कीमतें केवल एक अंक के बाद हैं (बाकी सभी नहीं दिखाई देते हैं), यह अनुमान लगाया गया है कि एक छोटी सी त्रुटि होगी। यह देखते हुए कि परिणाम मूल रूप से समान हैं, यह पूरी तरह से निश्चित नहीं है कि गेटटिकर द्वारा प्राप्त बाजार मूल्य और ओके फ्यूचर्स के आधिकारिक वेबसाइट पर अंतर शायद विनिमय दर असंगतता के कारण है।


प्रश्न 3: बिटकॉइन ओकेकॉइन प्लेटफॉर्म बाजार सूची समस्या (यह समस्या संशोधित है, अब बाजार सूची को रीट्यूनिंग और वास्तविक समय में एकीकृत किया गया है)https://www.fmz.com/bbs-topic/474


प्रश्न 4: कल देर रात, एक मित्र ने मुझसे पूछा कि रणनीति के बारे में क्या है, इंटरैक्टिव बटन का उपयोग करने के उदाहरण, मैंने सोचा, बस लिखना और अभ्यास करना, और वैसे भी, सभी के लिए सीखना आसान है, पुराने तरीके से, पहले कोड!

/* 交互按钮 测试
while (true) {
  var cmd = GetCommand();
  if (cmd) {
    Log(cmd);
  }
  Sleep(1000);
}
*/
function main(){
    var cmd = null; //初始化一些用到的变量,这个变量是直接接受 GetCommand 函数 返回值的。
    var jsonObjStr = null; //接收JSON对象字符串 的变量
    var jsonObj = null; // JSON 对象
    var keyValue = null; // JSON 对象中的  KEY 的值
    var arrStr = null; // 字符串数组
    var ticker = exchange.GetTicker(); 
    while(true){
        $.Draw(); // 画图函数 , 图表模板的 导出函数
        while(!ticker){
            ticker = exchange.GetTicker();
            Sleep(500);
        }
        cmd = GetCommand(); //获取  交互命令
        if (cmd) {
            Log("按下了按钮:",cmd);
            arrStr = cmd.split(":"); // GetCommand 函数返回的 是一个字符串,这里我处理的麻烦了,因为想熟悉一下JSON ,所以先对字符串做出处理,把函数返回的字符串以 : 号分割成2个字符串。储存在字符串数组中。
            
            
            jsonObjStr = '{' + '"' + arrStr[0] + '"' + ':' + arrStr[1] + '}'; // 把 字符串数组中的元素重新 拼接 ,拼接成 JSON 字符串  用于转换为JSON 对象。
            //Log(jsonObjStr);//ceshi
            //Log(typeof(cmd));//ceshi
            /*ceshi
            for(var obj1 in cmd){ //  测试用  注释掉了
                Log(cmd[obj1]);
            }
            */
            
            jsonObj = JSON.parse(jsonObjStr); // 转换为JSON 对象
            //Log("ceshi"); //ceshi
            for(var key in jsonObj){ // 遍历对象中的  成员名
                keyValue = jsonObj[key]; //取出成员名对应的 值 , 就是交互按钮的值
            }
            Log(keyValue); //ceshi 
            switch(keyValue){ // 分支选择 操作
                case 1:
                    $.SignOP((new Date()).getTime(),ticker.Last,1,keyValue ); //开多仓
                    break;
                case 2:
                    $.SignOP((new Date()).getTime(),ticker.Last,1,keyValue ); // 开空仓
                    break;
                case 0:
                    $.SignOP((new Date()).getTime(),ticker.Last,1,keyValue );//平仓
                    break;
                default: break;
            }
        }
        Sleep(2000);
    }
}

मैंने उपरोक्त कोड का परीक्षण किया है, और यह सार्वजनिक रूप से स्क्वायर में नहीं है, इसलिए दोस्तों को यह परीक्षण करने के लिए इंटरैक्टिव बटन को मैन्युअल रूप से जोड़ना होगा।imgइस तरह से आप ऊपर दी गई सेटिंग्स का उपयोग कर सकते हैं।

यहां देखें कि यह कैसे काम करता हैः

img img

बेशक, रणनीति पुनरावृत्ति का परीक्षण नहीं किया जा सकता है, आपको स्वयं रोबोट बनाने की आवश्यकता है, एक एनालॉग डिस्क का उपयोग करके परीक्षण करें, इंटरैक्टिव बटन पर क्लिक करें, चार्ट पर संबंधित ऑपरेशन को चिह्नित किया जाएगा। यहाँ कुंजी छोड़ दें, सभी को NB की रणनीति लिखने की उम्मीद है।


प्रश्न 5: एक उपयोगकर्ता ने पूछा कि वर्तमान में संचालित ई-मुद्रा का नाम कैसे प्राप्त किया जाए और वर्तमान के-लाइन चक्र कैसे प्राप्त किया जाए। वर्तमान एक्सचेंज की मुद्रा को प्राप्त करने के लिए एपीआई फ़ंक्शन का उपयोग किया जा सकता है, मैंने तुलनात्मक रूप से सरल तरीके से समस्या को हल किया है।

function main() {
    var records = exchange.GetRecords();
    while(!records || records.length < 2){
        records = exchange.GetRecords();
        Sleep(500);
    }
    var currency = exchange.GetCurrency();
    var diffTime = records[records.length - 1].Time - records[records.length - 2].Time;
    if(diffTime/1000 >= 1 && diffTime/1000 < 60){
        Log("周期:",diffTime/1000,"秒");
    }else if(diffTime/1000/60 >= 1 && diffTime/1000/60 < 60 ){
        Log("周期:",diffTime/1000/60,"分钟");
    }else if(diffTime/1000/60/60 >= 1 && diffTime/1000/60/60 < 24 ){
        Log("周期:",diffTime/1000/60/60,"小时");
    }else if(diffTime/1000/60/60/24 >= 1){
        Log("周期:",diffTime/1000/60/60/24,"天");
    }
    Log("货币品种:",currency);
}

यदि आप रुचि रखते हैं, तो आप इसका परीक्षण कर सकते हैं.


प्रश्न 6: यदि नए संस्करण के लिए कमोडिटी फ्यूचर्स ट्रेडिंग लाइब्रेरी में जोड़े गए फ़ंक्शनल फ़ंक्शन को समझ में नहीं आता है, तो नए एनोटेशन संस्करण कोड को QQ समूह में साझा किया जा सकता है।

  • रणनीति टेम्पलेट को रणनीति स्क्वायर पर प्रतिलिपिबद्ध किया जा सकता है।img

प्रश्न 7: x = [1 for i in range ((n)) का क्या अर्थ है?

  • इन दो दिनों के खाली समय में, मैं पायथन देख रहा था, सामान्य तौर पर सीखने में कोई कठिनाई नहीं थी, लेकिन फिर भी मुझे बहुत सारी समस्याएं आईं, मैं पहले याद करता हूं।

    प्रश्नः x = [1 for i in range ((n)) ] का क्या अर्थ है? जब मैंने पहली बार इसे देखा तो मेरा भी सिर बड़ा हो गया था, ऐसा लगता है कि मैंने पहले कभी नहीं देखा था। अनुमान लगाओ, अनुमान लगाओ, अनुमान लगाओ कि इसका क्या मतलब है। निश्चित रूप से, बाउटा ने भी पाया कि इस बारे में बहुत कुछ नहीं कहा गया था। सौभाग्य से, मुझे कुछ मिला।

यह पायथन में सूची विश्लेषण है, जिसका अर्थ है कि 1 से n तक की सूची बनाना। सूची विश्लेषण के बारे में निम्नलिखित विवरण देखेंः 1. परिभाषा और विवरण >पायथन की एक मजबूत विशेषता सूची का विश्लेषण है, जो एक संकुचित तरीका प्रदान करता है, जो सूची में प्रत्येक तत्व पर एक फ़ंक्शन लागू करके एक सूची को दूसरी सूची में मानचित्रित करता है. -> सूची विश्लेषण, जिसे सूची अवधारण भी कहा जाता है, सूची अवधारण की तुलना में अधिक सुव्यवस्थित और तेज़ है, विशेष रूप से बड़े डेटा के लिए, सूची अवधारण अधिकांश अवसरों में प्रतिस्थापन कर सकता है जहां नक्शा और फ़िल्टर का उपयोग करने की आवश्यकता होती है। सूची अवधारण लिंक बनाने का एक सरल तरीका प्रदान करता है, जिसमें मैप, फ़िल्टर और लैम्ब्डा का उपयोग नहीं किया जाता है। परिभाषित तरीके से सूची प्राप्त की जाती है, आमतौर पर इन समूहों को बनाने के लिए संरचनात्मक कार्यों का उपयोग करने की तुलना में स्पष्ट है। प्रत्येक सूची अवधारण में एक या अधिक for वाक्यांशों के बाद एक शून्य या if वाक्यांश शामिल होता है। यदि सूची के बाद एक या अधिक if वाक्यांशों का उपयोग किया जाना चाहिए, तो एक तत्व या if वाक्यांशों का एक सेट जोड़ा जाना चाहिए। 2. मूल सूची हल करना मूल [x for x in range ((5)] # [0, 1, 2, 3, 4] l1 = [1, 2, 3,4] [x*2 for x in l1] # [2, 4, 6,8] बहुमूल्य [ %s = %s for (k, v) in a_map.items (()) ] दो बार लूप l1 है [1, 2, 3,4] l2 बराबर है [1,2,3,4] [x + y के लिए x में l1 के लिए y में l2] [२, ३, ४, ५, ३, ४, ५, ६, ४, ५, ६, ७, ५, ६, ७, ८] फ़ंक्शन [ func ((x) for x in l1] # को map के बराबर बुलाया जा सकता है ध्यान दें कि सूची पार्सिंग मूल सूची के मान को नहीं बदलती है, बल्कि एक नई सूची बनाती है। 3. शर्त सूची हल करना [ x for x in range ((100) if x%2 ==0 ] 4., नेस्टेड सूची परिष्करणmat = [ [1, 2, 3], [4, 5, 6], [7, 8, 9]] स्विच मैट्रिक्स [ [row[i] for row in mat] for i in (0,1,2) ] # [[1, 4, 7, [2, 5, 8], [3, 6, 9]] यह लेख सीएसडीएन के ब्लॉग पर लिंगयू के लेख से लिया गया है।

सच कहूं तो, मैं ऊपर से कुछ भी नहीं समझता, लेकिन यह थोड़ा सा स्पष्ट लगता है कि इस वाक्य में कुछ पुनरावर्ती भूमिका होनी चाहिए।
यहां कुछ अन्य उत्साही लोगों के बारे में बताया गया हैः

i श्रेणी ((n) की सीमा में घूमता है, अर्थात् i = 0, 1, 2,..., n-1, क्रमशः गणना के लिए पहले अभिव्यक्ति के मान, सूची के पद के रूप में अभिव्यक्ति 1 है, जिसका मान 1,1,1..., n 1 के लिए है, जिससे n 1 युक्त सूची उत्पन्न होती है [1,1...]

यह एक बहुत स्पष्ट लग रहा है, चलो देखते हैं।

x = [i for i in list] एक सूची को दूसरी सूची में मैप करें, प्रत्येक तत्व को चर i के रूप में सेट करें x = [1 for i in range ((n) ] सूची रेंज ((n) को सूची x पर मैप करें, प्रत्येक तत्व को 1 पर सेट करें Forpython पर जाने के लिए आपका स्वागत है.

प्रश्न 8: पायथन आधार मजबूत नहीं है, रिटर्न किया गया है, आधे दिन के लिए अनदेखा किया गया है, नीचे समस्या देखें

कल मैंने एक परीक्षण रणनीति लिखी थी जो Python CTP कमोडिटी फ्यूचर्स के लिए एक समान लाइन का परीक्षण करती है। आज परीक्षण जारी है और पता चला है कि रणनीति पूरी तरह से सममित सोने के कांटे के साथ व्यापार करने के लिए बंद करने के लिए नहीं है, मुझे लगता है कि समस्याएं होनी चाहिए, प्रत्येक फ़ंक्शन की जांच, परीक्षण, और पता चलता है क्रॉसफंक्शन सही मान कोड को वापस नहीं करता है जैसा कि यह डिज़ाइन किया गया हैः

def Cross(records,fast,slow): # 交叉函数 ,参数是  records K线数据   、  fast 快线周期   、slow 慢线周期
    global array_S_MA,array_F_MA   # 使用外部的 全局变量
    array_F_MA = TA.MA(records,fast)  # 调用指标函数
    array_S_MA = TA.MA(records,slow)
    n = 0   # 返回的信号值   0:不操作   , 1 : 金叉     -1: 死叉 
    if array_F_MA[-2] > array_S_MA[-2] and array_F_MA[-3] < array_S_MA[-3] and array_F_MA[-4] < array_S_MA[-4]:
        n = 1
        return n
    elif array_F_MA[-2] < array_S_MA[-2] and array_F_MA[-3] > array_S_MA[-3] and array_F_MA[-4] > array_S_MA[-4]:
        n = -1 
        return n

कैसे? आप यह देख सकते हैं, एक बहुत ही नौसिखिया गलती! मैं वापस n शर्त शाखा में लिखा है, यह कोई समस्या नहीं लग रहा है. परीक्षण समस्या आ गया है, जब आप नहीं ट्रिगर गोल्डन कांटा, मृत कांटा, क्रॉस फ़ंक्शन और यह क्या लौटाता है?

हम एक छोटा सा प्रयोग करते हैंः

img

एक परीक्षण फ़ंक्शन को परिभाषित करें, केवल एक संदेश आउटपुट करें

img

हम इसे इस तरह लिखते हैं, और देखते हैं कि क्या कोई भी -1 के बराबर है।

img

परिणामों को देखते हुए, यह स्पष्ट है कि फ़ंक्शन में कोई रिटर्न निष्पादित नहीं होने पर फ़ंक्शन का रिटर्न मान None है, और None -1 के बराबर नहीं है, लेकिन यदि कोई 0 से छोटा है, तो यह सही है।

प्रश्न 9: JS लूपिंग संदर्भ समस्याएं।

उदाहरण के लिए, यह कोड त्रुटि देता हैः

function main(){
    obj = {
        exchange : null,
        initAccount : null,
        state : 0,
        exchangeName : "",
    }
    obj.name = "OKCoin";
    obj.exchange = exchange;
    obj.initAccount = obj.exchange.GetAccount();
    obj.state = 2;
    var table = {
        type : 'table',
        title : '测试',
        cols : ['obj属性名', '值'],
        rows : [],
    };
    for(var k in obj){
        table.rows.push([k, obj[k]]);
    }
    LogStatus('`' + JSON.stringify(table) + '`');
}

img

TypeError: Converting circular structure to JSON (यह त्रुटि मुझे आधे घंटे तक सताती रही!), इस त्रुटि की रिपोर्ट, बाइडो में एक बार जाँच की गई; यह कोड में एक घुमावदार संदर्भ है, जो JSON को हल नहीं कर सकता है।

यह एक समस्या है, क्योंकि यह एक समस्या है, और यह एक समस्या है।obj.exchange = exchange;इस वाक्य के परिणामस्वरूप लूप संदर्भ, निश्चित रूप से for ((var k in obj) लूप में k === exchange के साथ मिलता है, जब आगे कूदो, कोशिश करो।

यह कोड इस प्रकार हैः

function main(){
    obj = {
        exchange : null,
        initAccount : null,
        state : 0,
        exchangeName : "",
    }
    obj.name = "OKCoin";
    obj.exchange = exchange;
    obj.initAccount = obj.exchange.GetAccount();
    obj.state = 2;
    var table = {
        type : 'table',
        title : '测试',
        cols : ['obj属性名', '值'],
        rows : [],
    };
    for(var k in obj){
        if(k === 'exchange'){  // 增加的代码
            continue;
        }
        table.rows.push([k, obj[k]]);
    }
    LogStatus('`' + JSON.stringify(table) + '`');
}

img

यह सामान्य है, लेकिन क्या आप देख सकते हैं कि यह कैसे संदर्भित किया जाता है?

प्रश्न 10: कमोडिटी फ्यूचर्स शुक्रवार की रात को ट्रेड खोलें, ट्रेडों को पकड़ें, अगले सोमवार को ट्रेडों के खुलने के बाद, GetPosition फ़ंक्शन को कॉल करें, ट्रेडों के बारे में जानकारी प्राप्त करें, क्यों

img

इस तरह के लोगों के बारे में सोचने के लिए।

img

विशिष्ट पदों के प्रकार के गुणों के लिए विभिन्न मानों को देखेंःhttps://www.fmz.com/bbs-topic/672

यह देखकर, मुझे लगा कि मुझे अभ्यास करना चाहिए... और आप?

अधिक

बोटविज़िंग2सीधे पोस्ट करें।

छोटे सपनेमैं बहुत कुछ लिखने के लिए तैयार हूं, इसलिए मैंने एक विशेष क्यूक्यू स्पेस के लिए आवेदन किया है, ताकि यह देखने में भी आसान हो और इसे ढूंढना आसान हो।