export.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package main
  2. import (
  3. "fmt"
  4. "github.com/Jinnrry/pmail/config"
  5. "github.com/Jinnrry/pmail/db"
  6. "github.com/Jinnrry/pmail/hooks/spam_block/tools"
  7. "github.com/Jinnrry/pmail/models"
  8. "github.com/spf13/cast"
  9. "os"
  10. )
  11. func main() {
  12. args := os.Args
  13. var id int
  14. if len(args) >= 2 {
  15. id = cast.ToInt(args[1])
  16. }
  17. config.Init()
  18. err := db.Init("test")
  19. if err != nil {
  20. panic(err)
  21. }
  22. fmt.Println(config.Instance.DbDSN)
  23. fmt.Println("文件第一列是分类,0表示正常邮件,1表示垃圾邮件,2表示诈骗邮件")
  24. var start int
  25. file, err := os.OpenFile("data.csv", os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0777)
  26. if err != nil {
  27. fmt.Println(err)
  28. }
  29. defer file.Close()
  30. for {
  31. var emails []models.Email
  32. if id > 0 {
  33. db.Instance.Table(&models.Email{}).Where("id = ?", id).OrderBy("id").Find(&emails)
  34. } else {
  35. db.Instance.Table(&models.Email{}).Where("id > ?", start).OrderBy("id").Find(&emails)
  36. }
  37. if len(emails) == 0 {
  38. break
  39. }
  40. for _, email := range emails {
  41. start = email.Id
  42. content := tools.Trim(tools.TrimHtml(email.Html.String))
  43. if content == "" {
  44. content = tools.Trim(email.Text.String)
  45. }
  46. _, err = file.WriteString(fmt.Sprintf("0 \t%s %s\n", email.Subject, content))
  47. if err != nil {
  48. fmt.Println(err)
  49. }
  50. //fmt.Printf("0 \t%s %s\n", email.Subject, trim(trimHtml(email.Html.String)))
  51. }
  52. if id > 0 {
  53. break
  54. }
  55. }
  56. }