當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript iconv-lite.decode函數代碼示例

本文整理匯總了TypeScript中iconv-lite.decode函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript decode函數的具體用法?TypeScript decode怎麽用?TypeScript decode使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了decode函數的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: async

  router.post('/import/csv', upload.single('csv'), async (req, res) => {
    const storage = botScopedStorage.get(req.params.botId)
    const config = await bp.config.getModuleConfigForBot('qna', req.params.botId)

    const uploadStatusId = nanoid()
    res.end(uploadStatusId)

    updateUploadStatus(uploadStatusId, 'Deleting existing questions')
    if (yn(req.body.isReplace)) {
      const questions = await storage.fetchAllQuestions()

      const statusCb = processedCount =>
        updateUploadStatus(uploadStatusId, `Deleted ${processedCount}/${questions.length} questions`)
      await storage.delete(questions.map(({ id }) => id), statusCb)
    }

    try {
      const questions = iconv.decode(req.file.buffer, config.exportCsvEncoding)
      const params = {
        storage,
        config,
        format: 'csv',
        statusCallback: updateUploadStatus,
        uploadStatusId
      }
      await importQuestions(questions, params)

      updateUploadStatus(uploadStatusId, 'Completed')
    } catch (e) {
      bp.logger.error('Upload error :', e)
      updateUploadStatus(uploadStatusId, `Error: ${e.message}`)
    }
  })
開發者ID:seffalabdelaziz,項目名稱:botpress,代碼行數:33,代碼來源:api.ts

示例2: getNewsContent

  public async getNewsContent(newsURL: string): Promise<NewsContent> {
    try {
      await delay(5000);
      const response = await request({
        uri: newsURL,
        headers: commonHeaders,
        encoding: null,
      });

      let $ = cheerio.load(response);
      $('script').remove();
      const encodedResponse = iconv.decode(response, $('meta[charset]').attr('charset')).toString();
      $ = cheerio.load(encodedResponse);

      const newsTitle = $('meta[property=\'og:title\']').attr('content');
      const newsContent = $('#articeBody, #newsEndContents, #articleBodyContents');

      return {
        title: newsTitle,
        content: newsContent.html(),
        plain_text: newsContent.text(),
        press: $('.press_logo img, #pressLogo img').attr('alt'),
        link: newsURL,
      };
    } catch (err) {
      logger.error(err);
    }
  }
開發者ID:endlessdev,項目名稱:PortalRank,代碼行數:28,代碼來源:naver-parser.ts

示例3:

 }).then(function(result): Buffer {
     if (encoding != null && encoding != "") {
         var decoded = iconv.decode(result.stdout, encoding);
         return decoded;
     }
     return result.stdout;
 }).fail(function(error) {
開發者ID:bbenoist,項目名稱:code-gnu-global,代碼行數:7,代碼來源:global.ts

示例4: Error

		testFixture.forEach(set => {
			console.log('File:', set.file);
			console.log('Exists:', fs.existsSync(set.file));
			if (fs.existsSync(set.file)) {
				let data = fs.readFileSync(set.file);
				data = iconv.decode(data, "ISO-8859-1");
				let parse = new ParseCSV(data);
				let nice = parse.parseAndNormalize();

				if (nice.length != set.rows) {
					console.log('parsed', nice.length, 'rows, expecting', set.rows);
					console.log(nice);
					throw new Error('number of rows is not the same');
				}

				let row0 = this.pluckImportant(nice[0]);
				let row1 = this.pluckImportant(nice[1]);

				// if (_.isEqual(row0, set.result[0]) && _.isEqual(row1, set.result[1])) {
				if (JSON.stringify(row0) == JSON.stringify(set.result[0])
					&& JSON.stringify(row1) == JSON.stringify(set.result[1])) {
					console.log('OK');
				} else {
					console.error('Parsed file does not match');
					console.log(JSON.stringify(row0, null, 4));
					console.log(JSON.stringify(set.result[0], null, 4));
					console.log(JSON.stringify(row1, null, 4));
					console.log(JSON.stringify(set.result[1], null, 4));
					throw new Error(set.file + ' test failed');
				}
			}
		});
開發者ID:spidgorny,項目名稱:umsaetze,代碼行數:32,代碼來源:TestImport.ts

示例5: sendPromise

async  function  sendPromise(){

    let data   =  await send("http://bcy.net/coser/");
    let ddd = await zibPromise(data);
     data = iconv.decode(ddd, 'utf-8');
    console.log(data);
}
開發者ID:zcg331793187,項目名稱:DownloadYouLike,代碼行數:7,代碼來源:testWeb.ts

示例6: Buffer

(() => {
	// Convert from an encoded buffer to js string.
	const str: string = iconv.decode(new Buffer([0x68, 0x65, 0x6c, 0x6c, 0x6f]), 'win1251');

	// Convert from js string to an encoded buffer.
	const buf: Buffer = iconv.encode("Sample input string", 'win1251');

	// Check if encoding is supported
	const exists: boolean = iconv.encodingExists("us-ascii");
})();
開發者ID:AbraaoAlves,項目名稱:DefinitelyTyped,代碼行數:10,代碼來源:iconv-lite-tests.ts

示例7: resolve

        return new Promise<vscode.Hover>((resolve) => {
            const charEncoding = vscode.workspace.getConfiguration('hexdump').get<string>('charEncoding');
            const littleEndian = vscode.workspace.getConfiguration('hexdump').get<boolean>('littleEndian');
            const showInspector = vscode.workspace.getConfiguration('hexdump').get<boolean>('showInspector');

            if (!showInspector) {
                return resolve();
            }
            let offset = getOffset(position);
            if (typeof offset == 'undefined') {
                return resolve();
            }

            var content: string = 'Hex Inspector';
            content += littleEndian ? ' Little Endian\n' : ' Big Endian\n';
            content += 'Address: 0x' + sprintf('%08X', offset) + '\n';

            let sel = vscode.window.activeTextEditor.selection;
            if (sel.contains(position)) {
                let start = getOffset(sel.start);
                let end = getOffset(sel.end);
                content += 'Selection: 0x' + sprintf('%08X', start) 
                content += ' - 0x' + sprintf('%08X', end) + ' \n';
            }

            let buf = getBuffer(document.uri);
            if (typeof buf == 'undefined') {
                return resolve();
            }

            let arrbuf = toArrayBuffer(buf, offset, 8);
            var view = new DataView(arrbuf);

            content += 'Int8:   ' + sprintf('%12d', view.getInt8(0)) + '\t';
            content += 'Uint8:  ' + sprintf('%12d', view.getUint8(0)) + ' \n';
            content += 'Int16:  ' + sprintf('%12d', view.getInt16(0, littleEndian)) + '\t';
            content += 'Uint16: ' + sprintf('%12d', view.getUint16(0, littleEndian)) + ' \n';
            content += 'Int32:  ' + sprintf('%12d', view.getInt32(0, littleEndian)) + '\t';
            content += 'Uint32: ' + sprintf('%12d', view.getUint32(0, littleEndian)) + ' \n';
            content += 'Int64:  ' + Long.fromBytes(new Uint8Array(arrbuf), true, littleEndian).toString() + ' \n';
            content += 'Uint64: ' + Long.fromBytes(new Uint8Array(arrbuf), false, littleEndian).toString() + ' \n';
            content += 'Float32: ' + sprintf('%f', view.getFloat32(0, littleEndian)) + ' \n';
            content += 'Float64: ' + sprintf('%f', view.getFloat64(0, littleEndian)) + ' \n';
            content += '\n';

            if (sel.contains(position)) {
                let start = getOffset(sel.start);
                let end = getOffset(sel.end) + 1;
                content += 'String (' + charEncoding + '):\n';
                let conv = iconvLite.decode(buf.slice(start, end), charEncoding);
                content += conv.toString();
            }

            return resolve(new vscode.Hover( {language: 'hexdump', value: content} )) ;
        });
開發者ID:stef-levesque,項目名稱:vscode-hexdump,代碼行數:55,代碼來源:hoverProvider.ts

示例8: _handleDataChunk

 private _handleDataChunk(data: Buffer) {
     // Anatomy of packets: [data length] [NULL] [xml] [NULL]
     // are we waiting for the data length or for the response?
     if (this._parsingState === ParsingState.DataLength) {
         // does data contain a NULL byte?
         const nullByteIndex = data.indexOf(0);
         if (nullByteIndex !== -1) {
             // YES -> we received the data length and are ready to receive the response
             this._dataLength = parseInt(iconv.decode(data.slice(0, nullByteIndex), ENCODING));
             // reset buffered chunks
             this._chunks = [];
             this._chunksDataLength = 0;
             // switch to response parsing state
             this._parsingState = ParsingState.Response;
             // if data contains more info (except the NULL byte)
             if (data.length > nullByteIndex + 1) {
                 // handle the rest of the packet as part of the response
                 const rest = data.slice(nullByteIndex + 1);
                 this._handleDataChunk(rest);
             }
         } else {
             // NO -> this is only part of the data length. We wait for the next data event
             this._chunks.push(data);
             this._chunksDataLength += data.length;
         }
     } else if (this._parsingState === ParsingState.Response) {
         // does the new data together with the buffered data add up to the data length?
         if (this._chunksDataLength + data.length >= this._dataLength) {
             // YES -> we received the whole response
             // append the last piece of the response
             const lastResponsePiece = data.slice(0, this._dataLength - this._chunksDataLength);
             this._chunks.push(lastResponsePiece);
             this._chunksDataLength += data.length;
             const response = Buffer.concat(this._chunks, this._chunksDataLength);
             // call response handler
             this.handleResponse(parseResponse(response));
             // reset buffer
             this._chunks = [];
             this._chunksDataLength = 0;
             // switch to data length parsing state
             this._parsingState = ParsingState.DataLength;
             // if data contains more info (except the NULL byte)
             if (data.length > lastResponsePiece.length + 1) {
                 // handle the rest of the packet (after the NULL byte) as data length
                 const rest = data.slice(lastResponsePiece.length + 1);
                 this._handleDataChunk(rest);
             }
         } else {
             // NO -> this is not the whole response yet. We buffer it and wait for the next data event.
             this._chunks.push(data);
             this._chunksDataLength += data.length;
         }
     }
 }
開發者ID:lshain,項目名稱:vscode-php-debug,代碼行數:54,代碼來源:dbgp.ts

示例9: decode

 decode(
     data: DataView,
     byteOffset: number,
     byteLength: number,
     encoding: string,
 ): string {
     const buffer = Buffer.from(
         data.buffer,
         data.byteOffset + byteOffset,
         byteLength,
     )
     return decode(buffer, encoding)
 }
開發者ID:mysticatea,項目名稱:bre,代碼行數:13,代碼來源:iconv-lite.ts

示例10: Buffer

 rollbar.invoke('Processing "data" event from proc stdout', {data, command, args}, () => {
   const str = iconv.decode(new Buffer(data), encoding);
   const lines = str.split('\n').map(l => l.endsWith('\r') ? l.substr(0, l.length - 1) : l);
   while (lines.length > 1) {
     line_acc += lines[0];
     if (outputConsumer) {
       outputConsumer.output(line_acc);
     }
     line_acc = '';
     // Erase the first line from the list
     lines.splice(0, 1);
   }
   console.assert(lines.length, 'Invalid lines', JSON.stringify(lines));
   line_acc += lines[0];
   stdout_acc += str;
 });
開發者ID:vector-of-bool,項目名稱:vscode-cmake-tools,代碼行數:16,代碼來源:proc.ts


注:本文中的iconv-lite.decode函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。