婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 淺析Go語(yǔ)言版本的forgery

淺析Go語(yǔ)言版本的forgery

熱門(mén)標(biāo)簽:南通如皋申請(qǐng)開(kāi)通400電話(huà) 中國(guó)地圖標(biāo)注省會(huì)高清 地圖標(biāo)注的汽車(chē)標(biāo) 浙江高速公路地圖標(biāo)注 西部云谷一期地圖標(biāo)注 廣州呼叫中心外呼系統(tǒng) 江西轉(zhuǎn)化率高的羿智云外呼系統(tǒng) 學(xué)海導(dǎo)航地圖標(biāo)注 高德地圖標(biāo)注口訣

使用過(guò)Python語(yǔ)言的朋友們可能使用過(guò) forgery_py ,它是一個(gè)偽造數(shù)據(jù)的工具。能偽造一些常用的數(shù)據(jù)。在我們開(kāi)發(fā)過(guò)程和效果展示是十分有用。但是沒(méi)有Go語(yǔ)言版本的,所以就動(dòng)手折騰吧。

從源碼入手

在forgery_py的 PyPi 有一段的實(shí)例代碼:

>>> import forgery_py
>>> forgery_py.address.street_address()
u'4358 Shopko Junction'
>>> forgery_py.basic.hex_color()
'3F0A59'
>>> forgery_py.currency.description()
u'Slovenia Tolars'
>>> forgery_py.date.date()
datetime.date(2012, 7, 27)
>>> forgery_py.internet.email_address()
u'brian@zazio.mil'
>>> forgery_py.lorem_ipsum.title()
u'Pretium nam rhoncus ultrices!'
>>> forgery_py.name.full_name()
u'Mary Peters'
>>> forgery_py.personal.language()
u'Hungarian'

從以上的方法調(diào)用我們可以看出forgery_py下有一系列的 *.py 文件,里面有各種方法,實(shí)現(xiàn)各種功能,我們?cè)趤?lái)通過(guò)分析下Python版本的forgery_py的源碼來(lái)看看它的實(shí)現(xiàn)原理。

# ForgeryPy 包的一級(jí)目錄
├── dictionaries # 偽造內(nèi)容和來(lái)源目錄,目錄下存放的都是一些文本文件
├── dictionaries_loader.py # 加載文件腳本
├── forgery    # 主目錄,實(shí)現(xiàn)各種數(shù)據(jù)偽造功能,目錄下存放的都是python文件
├── __init__.py

我們?cè)趤?lái)看下forgery目錄下的腳本

$ cat name.py
import random
from ..dictionaries_loader import get_dictionary
__all__ = [
  'first_name', 'last_name', 'full_name', 'male_first_name',
  'female_first_name', 'company_name', 'job_title', 'job_title_suffix',
  'title', 'suffix', 'location', 'industry'
]
def first_name():
  """Random male of female first name."""
  _dict = get_dictionary('male_first_names')
  _dict += get_dictionary('female_first_names')
  return random.choice(_dict).strip()

__all__ 設(shè)置能被調(diào)用的方法。

first_name() 方法是forgery_py中一個(gè)典型偽造數(shù)據(jù)方法,我們只要來(lái)分析它就可以知道forgery_py的工作原理了。

這個(gè)方法代碼很少,能容易就看出 _dict = get_dictionary('male_first_names') _dict += get_dictionary('female_first_names') 獲取的數(shù)據(jù)合并,在最后的 return random.choice(_dict).strip() 返回隨機(jī)的數(shù)據(jù)。它的重點(diǎn)在于 get_dictionary() ,所以我們需要來(lái)看它的所在位置 dictionaries_loader.py 文件。

$ cat dictionaries_loader
import random
DICTIONARIES_PATH = abspath(join(dirname(__file__), 'dictionaries'))
dictionaries_cache = {}
def get_dictionary(dict_name):
  """
  Load a dictionary file ``dict_name`` (if it's not cached) and return its
  contents as an array of strings.
  """
  global dictionaries_cache
  if dict_name not in dictionaries_cache:
    try:
      dictionary_file = codecs.open(
        join(DICTIONARIES_PATH, dict_name), 'r', 'utf-8'
      )
    except IOError:
      None
    else:
      dictionaries_cache[dict_name] = dictionary_file.readlines()
      dictionary_file.close()
  return dictionaries_cache[dict_name]

以上就是 dictionaries_loader.py 文件去掉注釋后的所以要內(nèi)容。它的主要實(shí)現(xiàn)就是:定義一個(gè)全局的字典參數(shù) dictionaries_cache 作為緩存,然后定義方法 get_dictionary() 獲取源數(shù)據(jù), get_dictionary() 中每次forgery目錄底下方法調(diào)用時(shí)先查看緩存,緩存字典中存在數(shù)據(jù)就直接輸出,不存在就讀取 dictionaries 底下的對(duì)應(yīng)文件,并存入緩存。最后是返回?cái)?shù)據(jù)。

總的來(lái)說(shuō)forgery_py的原理就是:一個(gè)方法調(diào)用,去讀內(nèi)存中的緩存,存在就直接返回,不存在就到對(duì)應(yīng)的文本文件中讀取并寫(xiě)入緩存并返回。返回來(lái)的數(shù)據(jù)再隨機(jī)選取輸出結(jié)果。

使用Go語(yǔ)言實(shí)現(xiàn)

在了解了forgery_py的工作原理之后,我們就可以來(lái)使用Go語(yǔ)言來(lái)實(shí)現(xiàn)了。

# forgery的基本目錄
$ cat forgery
├── dictionaries # 數(shù)據(jù)源
│  ├── male_first_names
├── name.go  # 具體功能實(shí)現(xiàn)
└── loader.go # 加載數(shù)據(jù)

根據(jù)python版本的我們也來(lái)創(chuàng)建對(duì)應(yīng)的目錄。

實(shí)現(xiàn)數(shù)據(jù)的讀取的緩存:

// forgery/loader.go
package forgery
import (
  "os"
  "io"
  "bufio"
  "math/rand"
  "time"
  "strings"
)
// 全局的緩存map
var dictionaries map[string][]string = make(map[string][]string)
// 在獲取數(shù)據(jù)之后隨機(jī)輸出
func random(slice []string) string {
  rand.Seed(time.Now().UnixNano())
  n := rand.Intn(len(slice))
  return strings.TrimSpace(slice[n])
}
// 主要的數(shù)據(jù)加載方法
func loader(name string) (slice []string, err error) {
  slice, ok := dictionaries[name]
  // 緩存中存在數(shù)據(jù),直接返回
  if ok {
    return slice, nil
  }
  // 讀取對(duì)應(yīng)文件
  file, err := os.Open("./dictionaries/" + name)
  if err != nil {
    return slice, err
  }
  defer file.Close()
  rd := bufio.NewReader(file)
  for {
    line, err := rd.ReadString('\n')
    slice = append(slice, line)
    if err != nil || io.EOF == err {
      break
    }
  }
  dictionaries[name] = slice
  return slice, nil
}
// 統(tǒng)一的錯(cuò)誤處理
func checkErr(err error) (string, error) {
  return "", err
}

實(shí)現(xiàn)具體的功能:

// forgery/name.go
// Random male of female first name.
func FirstName() (string, error) {
  slice, err := loader("male_first_names")
  checkErr(err)
  slice1, err := loader("female_first_names")
  checkErr(err)
  slice = append(slice, slice1...)
  return random(slice), nil
}

這樣就將python語(yǔ)言版本的forgery_py使用Go來(lái)實(shí)現(xiàn)了。

最后

上面只是提及了一些工作原理,具體的源代碼可以看 https://github.com/xingyys/fo... ,也十分感謝 https://github.com/tomekwojci... ,具體的思路和里面的數(shù)據(jù)源都是他提供的。本人就是做了一些 翻譯 的的工作。

總結(jié)

以上所述是小編給大家介紹的Go語(yǔ)言版本的forgery,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

標(biāo)簽:吐魯番 常州 德宏 曲靖 許昌 貴州 保定 東營(yíng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《淺析Go語(yǔ)言版本的forgery》,本文關(guān)鍵詞  淺析,語(yǔ)言,版本,的,forgery,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《淺析Go語(yǔ)言版本的forgery》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于淺析Go語(yǔ)言版本的forgery的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 西峡县| 铜山县| 托克托县| 舒兰市| 逊克县| 塔城市| 安平县| 左云县| 遂昌县| 苍溪县| 南溪县| 凭祥市| 枣阳市| 青岛市| 奇台县| 东方市| 巴林左旗| 博白县| 九龙坡区| 墨江| 苍山县| 新营市| 铜山县| 民县| 罗山县| 珠海市| 赤城县| 沂南县| 古交市| 清徐县| 郯城县| 于田县| 揭西县| 塔河县| 建平县| 义马市| 阿克陶县| 古丈县| 临湘市| 大余县| 静安区|