Apri 알고리즘 Python 구현
2002 단어 python
#!C:/Python27/python.exe
#coding=gbk
import sys
__author__ = "junfeng_feng"
"""Python Apri
input:
ouput:
Usage:python Apri.py filename min_surpport
Exampe: python Apri.py data.txt 2
3
1、 Python 70 , Apri
2、 (Python )
3、 ,
:
1、 ,
2、 apri,
data.txt
A C D
B C E
A B C E
B E
"""
# C1
#return: key=item;value=item
def getC1(srcdata):
c1 = {}
for transaction in srcdata:
for item in transaction:
key = frozenset(set([item])) #frozenset key
# item
if key in c1:
c1[key] = c1[key] + 1
else:
c1[key] = 1
return c1
#return:
def getL(c, supct):
# item
for key in [item for item in c if c[item] < supct]:
del c[key]
return c
# L C
# , item
def getnextcandi(preL, srcdata):
c = {}
for key1 in preL:
for key2 in preL:
if key1 != key2:
# preL preL
key = key1.union(key2)
c[key] = 0
# item
for i in srcdata:
for item in c:
if item.issubset(i):
c[item] = c[item] + 1
return c
# Apriori
def Apriori(filename, supct):
#
# : , Tab(\t)
srcdata = [line.strip().split("\t") for line in file(filename)]
c = getC1(srcdata)
L = {}
while True:
temp_L = getL(c, supct)
if not temp_L:
break
else:
L = temp_L
# L, c
c = getnextcandi(L, srcdata)
return L
if __name__ == "__main__":
if len(sys.argv) == 3:
#Usage: apri.py filename surpport
print Apriori(sys.argv[0], sys.argv[1])
else:
#for example
print Apriori("awk.txt", 8)
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.