Heim >Backend-Entwicklung >Python-Tutorial >Wie sollen Python-Crawler-Daten verarbeitet werden?
Variablenlänge()-Funktion festlegen char_length() Funktion ersetzen() max()-Funktion
Variablensatz @Variablenname=Wert festlegen
set @address='中国-山东省-聊城市-莘县';select @address1.2. Unterschiede zwischen der Funktion length() char_length()
select length('a') ,char_length('a') ,length('中') ,char_length('中')1.3. Kombination der Funktion replacement() und der Funktion length()
set @address='中国-山东省-聊城市-莘县';select @address ,replace(@address,'-','') as address_1 ,length(@address) as len_add1 ,length(replace(@address,'-','')) as len_add2 ,length(@address)-length(replace(@address,'-','')) as _countetl-Reinigung field Wie kann man bestimmen, wie viele getrennte Felder zu einer neuen Datentabelle hinzugefügt werden sollen, wenn offensichtliche Trennzeichen vorhanden sind? Berechnen Sie die maximale Anzahl von - Zeichen in com_industry, um zu bestimmen, wie viele Felder hinzugefügt werden können Die Anzahl der Felder in dieser Tabelle beträgt 3, sodass sie in 4 Branchenfelder aufgeteilt werden kann, d
select max(length(com_industry)-length(replace(com_industry,'-',''))) as _max_count from etl1_socom_data1.5. Bedingte Beurteilungsfunktion, Fall, wenn
Fall, wenn dann, wenn dann sonst der Wert als Feldname endet
set @address='中国-山东省-聊城市-莘县'; select substring_index(@address,'-',1) as china, substring_index(substring_index(@address,'-',2),'-',-1) as province, substring_index(substring_index(@address,'-',3),'-',-1) as city, substring_index(@address,'-',-1) as district
2. Kesselkonvertierung etl1 Reinigung
select case when 89>101 then '大于' else '小于' end as betl1_socom_data-Feldindex erwähnt den Indexalgorithmus nicht. Es wird empfohlen, den BTREE-Algorithmus zu verwenden, um die Abfrageeffizienz zu verbessern 2.1.kettle-Dateiname: trans_etl1_socom_data
2.2. Steuerelemente einbeziehen: Tabelleneingabe>>> 1 Screenshot
2.4, Tabelleneingabe 2.4, SQL-Skript-Vorreinigung der Felder com_district und com_industry
<code class="sql"><span class="hljs-keyword">select a.*,<span class="hljs-keyword">case <span class="hljs-keyword">when com_district <span class="hljs-keyword">like <span class="hljs-string">'%业' <span class="hljs-keyword">or com_district <span class="hljs-keyword">like <span class="hljs-string">'%织' <span class="hljs-keyword">or com_district <span class="hljs-keyword">like <span class="hljs-string">'%育' <span class="hljs-keyword">then <span class="hljs-literal">null <span class="hljs-keyword">else com_district <span class="hljs-keyword">end <span class="hljs-keyword">as com_district1 ,<span class="hljs-keyword">case <span class="hljs-keyword">when com_district <span class="hljs-keyword">like <span class="hljs-string">'%业' <span class="hljs-keyword">or com_district <span class="hljs-keyword">like <span class="hljs-string">'%织' <span class="hljs-keyword">or com_district <span class="hljs-keyword">like <span class="hljs-string">'%育' <span class="hljs-keyword">then <span class="hljs-keyword">concat(com_district,<span class="hljs-string">'-',com_industry) <span class="hljs-keyword">else com_industry <span class="hljs-keyword">end <span class="hljs-keyword">as com_industry_total ,<span class="hljs-keyword">replace(com_addr,<span class="hljs-string">'地 址:',<span class="hljs-string">'') <span class="hljs-keyword">as com_addr1 ,<span class="hljs-keyword">replace(com_phone,<span class="hljs-string">'电 话:',<span class="hljs-string">'') <span class="hljs-keyword">as com_phone1 ,<span class="hljs-keyword">replace(com_fax,<span class="hljs-string">'传 真:',<span class="hljs-string">'') <span class="hljs-keyword">as com_fax1 ,<span class="hljs-keyword">replace(com_mobile,<span class="hljs-string">'手机:',<span class="hljs-string">'') <span class="hljs-keyword">as com_mobile1 ,<span class="hljs-keyword">replace(com_url,<span class="hljs-string">'网址:',<span class="hljs-string">'') <span class="hljs-keyword">as com_url1 ,<span class="hljs-keyword">replace(com_email,<span class="hljs-string">'邮箱:',<span class="hljs-string">'') <span class="hljs-keyword">as com_email1 ,<span class="hljs-keyword">replace(com_contactor,<span class="hljs-string">'联系人:',<span class="hljs-string">'') <span class="hljs-keyword">as com_contactor1 ,<span class="hljs-keyword">replace(com_emploies_nums,<span class="hljs-string">'公司人数:',<span class="hljs-string">'') <span class="hljs-keyword">as com_emploies_nums1 ,<span class="hljs-keyword">replace(com_reg_capital,<span class="hljs-string">'注册资金:万',<span class="hljs-string">'') <span class="hljs-keyword">as com_reg_capital1 ,<span class="hljs-keyword">replace(com_type,<span class="hljs-string">'经济类型:',<span class="hljs-string">'') <span class="hljs-keyword">as com_type1 ,<span class="hljs-keyword">replace(com_product,<span class="hljs-string">'公司产品:',<span class="hljs-string">'') <span class="hljs-keyword">as com_product1 ,<span class="hljs-keyword">replace(com_desc,<span class="hljs-string">'公司简介:',<span class="hljs-string">'') <span class="hljs-keyword">as com_desc1<span class="hljs-keyword">from s_socom_data <span class="hljs-keyword">as a</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></code><br/><br/><br/>Hinweise:
① Aktivieren Sie die Option „Tabelle ausschneiden“ nicht, wenn inkrementelle Crawler-Vorgänge beteiligt sind
②Datenverbindungsprobleme Wählen Sie die Datenbank aus, in der Die Tabelle in der Tabellenausgabe befindet sich
Führen Sie hauptsächlich die Feldaufteilung und -bereinigung auf dem neuen durch com_industry generiert von etl1
3.1.kettle Dateiname: trans_etl2_socom_data
3.2. Einschließlich Steuerelemente: Tabelleneingabe>>> Tabellenausgabe
3.3. Datenflussrichtung: etl1_socom_data>>>>etl2_socom_data
③Feldzuordnungsprobleme stellen sicher, dass die Nummer der Felder im Datenstrom und in der physischen Tabelle sind konsistent
Screenshot der Kettle-Konvertierung 2
3.4 Das SQL-Skript teilt com_industry und schließt die Bereinigung ab aller Felder. Registrierte Kapitalfeld-Zeitbeziehungen können ohne detaillierte Demontage und Anpassung des Codes angepasst werden
select a.*,case #行业为''的值 置为空when length(com_industry)=0 then null #其他的取第一个-分隔符之前else substring_index(com_industry,'-',1) end as com_industry1,case when length(com_industry)-length(replace(com_industry,'-',''))=0 then null #'交通运输、仓储和邮政业-' 这种值 行业2 也置为nullwhen length(com_industry)-length(replace(com_industry,'-',''))=1 and length(substring_index(com_industry,'-',-1))=0 then nullwhen length(com_industry)-length(replace(com_industry,'-',''))=1 then substring_index(com_industry,'-',-1)else substring_index(substring_index(com_industry,'-',2),'-',-1)end as com_industry2,case when length(com_industry)-length(replace(com_industry,'-',''))<=1 then nullwhen length(com_industry)-length(replace(com_industry,'-',''))=2 then substring_index(com_industry,'-',-1)else substring_index(substring_index(com_industry,'-',3),'-',-1)end as com_industry3,case when length(com_industry)-length(replace(com_industry,'-',''))<=2 then nullelse substring_index(com_industry,'-',-1)end as com_industry4from etl1_socom_data as awird nicht empfohlen, wenn die Datenmenge groß ist.
4.3 Überprüfen Sie die ETL-Reinigungsqualität
select count(1) from s_socom_dataunion all select count(1) from etl1_socom_dataunion all select count(1) from etl2_socom_dataSuchen Sie die Seiten-URL und Website-Daten zur Überprüfungwo es so geschrieben ist. Es ist praktisch, den Reinigungsstatus von a zu überprüfen bestimmtes Feld
select * from etl2_socom_data where com_district is null and length(com_industry)-length(replace(com_industry,'-',''))=3etl2_socom_data Tabellendaten
Das obige ist der detaillierte Inhalt vonWie sollen Python-Crawler-Daten verarbeitet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!